【发布时间】:2021-09-19 02:23:19
【问题描述】:
我不知道该怎么说这句话。所以我目前正在使用 select2 和我正在制作的结帐系统。这个想法是,在结帐的表单上,有人可以使用选择列表(使用 select2)一次结帐多个项目,我希望将这些项目存储在数据库中的字符串中。它加载正常,但是当我尝试提交表单时,它返回一个错误,因为它返回 null 并且无法将值作为字符串获取。不知道该怎么办。任何意见是极大的赞赏。这是我到目前为止所拥有的:
模型类和视图模型:
public class CheckedOutItem
{
public int Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public string Department { get; set; }
public string Role { get; set; }
public string Items{ get; set; }
public string UserId { get; set; }
[NotMapped]
public string[] SelectedItems { get; set; }
[DataType(DataType.DateTime)]
[DisplayFormat(DataFormatString = "{MM/dd/yyyy h:mm tt}")]
[Display(Name = "Date Checked Out")]
public DateTimeOffset DateCheckedOut { get; set; }
= DateTime.Now;
}
public class CheckOutItemVM
{
public int Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public string Department { get; set; }
public string Role { get; set; }
public string Items{ get; set; }
public string UserId { get; set; }
[NotMapped]
public string[] SelectedItems { get; set; }
[DataType(DataType.DateTime)]
[Display(Name = "Date Checked Out")]
[DisplayFormat(DataFormatString = "{MM/dd/yyyy h:mm tt}")]
public DateTimeOffset DateCheckedOut { get; set; }
= DateTime.Now;
public CheckOutItem GetCheckOuttInstance()
{
return new CheckOutItem
{
Id = 0,
UserId = this.UserId,
FirstName = this.FirstName,
LastName = this.LastName,
Items = this.Items,
Department = this.Department,
Role= this.Role,
DateCheckedOut = this.DateCheckedOut,
SelectedItems = this.SelectedItems,
};
}
}
在控制器中:
[HttpGet]
public IActionResult CheckOutItems()
{
ViewBag.ItemId= new SelectList(_itemRepo.ReadItemList(), "Id", "Name");
return View();
}
[HttpPost, ValidateAntiForgeryToken]
public IActionResult CheckOutItems(CheckOutItemVM itemVM)
{
var checkout = itemVM.GetCheckOuttInstance();
var itemsToCheckout = new CheckOutItemVM
{
UserId = checkout.UserId,
FirstName = checkout.FirstName,
LastName = checkout.LastName,
Department = checkout.Department,
Role = checkout.Role,
DateCheckedOut = checkout.DateCheckedOut,
SelectedItems = checkout.SelectedItems,
Items = checkout.Items
};
_itemRepo.CheckOutItems(checkout);
RedirectToAction("CheckOutItems", "Item");
//ModelState.Clear();
return View(itemsToCheckout);
}
在视图中:
<link href="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.13/css/select2.min.css" rel="stylesheet" />
<script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.13/js/select2.min.js"></script>
<script type="text/javascript">
$(document).ready(function () {
var items = $(".itemSelect").select2();
});
</script>
<h1>@ViewData["Title"]</h1>
<hr />
<div class="row">
<div class="col-md-4">
<form asp-action="CheckOutItems">
<div asp-validation-summary="ModelOnly" class="text-danger"></div>
<div class="form-group">
<label asp-for="UserId" class="control-label">User ID</label>
<input id="UserId" asp-for="UserId" class="form-control" />
<span asp-validation-for="UserId" class="text-danger"></span>
</div>
<div class="form-group">
<label asp-for="FullName" class="control-label">Full Name</label>
<input id="FullName" asp-for="FullName" class="form-control" />
<span asp-validation-for="FullName" class="text-danger"></span>
</div>
<div class="form-group">
<label asp-for="Department" class="control-label"></label>
<input id="Department" asp-for="Department" class="form-control" />
<span asp-validation-for="Department" class="text-danger"></span>
</div>
<div class="form-group">
<label asp-for="Role" class="control-label">Role</label>
<input id="Role" asp-for="Role" class="form-control" />
<span asp-validation-for="Role" class="text-danger"></span>
</div>
<div class="form-group">
<label asp-for="Items" class="control-label">Items</label>
<select asp-for="Items" class="itemSelect form-control" name="items" multiple asp-items="ViewBag.ItemId">
<option value="Select Items(s) To Checkout" disabled></option>
</select>
</div>
<div class="form-group">
<label asp-for="DateCheckedOut" class="control-label" hidden></label>
<input asp-for="DateCheckedOut" class="form-control" hidden />
<span asp-validation-for="DateCheckedOut" class="text-danger" hidden></span>
</div>
<div class="form-group">
<input type="submit" value="Check Out" class="btn btn-primary" />
</div>
</form>
</div>
</div>
<div>
<a asp-action="Index">Back to List</a>
</div>
@section Scripts {
@{await Html.RenderPartialAsync("_ValidationScriptsPartial");
}
<script src="~/select2/js/select2.full.min.js"></script>
<script src="~/select2/js/select2.js"></script>
【问题讨论】:
标签: c# jquery asp.net-core jquery-select2