繁体   English   中英

"ArgumentNullException: Value cannot be null. (Parameter 'items')" 使用视图中的下拉列表 asp.net mvc 创建新的数据库记录

[英]"ArgumentNullException: Value cannot be null. (Parameter 'items')" using a dropdown in the view asp.net mvc to create new database records

当我尝试创建新的数据库记录时,我收到错误“ArgumentNullException: Value cannot be null. (Parameter 'items')”。 我可以在 asp.net MVC 5 中编辑数据库记录,但不能创建它们。

我的模型是:

using System.ComponentModel.DataAnnotations.Schema;

namespace Speakers2.Models
{
    [Table("SpeakerStatus", Schema = "SalesOps")]
    public partial class SpeakerStatusLookupModel
    {
        public int Id { get; set; }
        public string SpeakerStatus { get; set; }
    }
}

上下文是:

using Microsoft.EntityFrameworkCore;
using Speakers2.Models;

namespace Speakers2.Data
{
    public class Speakers2Context : DbContext
    {
        public Speakers2Context(DbContextOptions<Speakers2Context> options)
            : base(options)
        {
        }

        public DbSet<SpeakerStatusLookupModel> SpeakerStatusLookupModel { get; set; }
    }
}

观点是:

@model Speakers2.Models.SpeakerQuery

@{
    ViewData["Title"] = "Create";
}

<h1>Create</h1>

<h4>Speaker</h4>
<hr />
<div class="row">
    <div class="col-md-4">
        <form asp-action="Create">
            <div asp-validation-summary="ModelOnly" class="text-danger"></div>
            <div class="form-group">   
                <label asp-for="SpeakerStatus" class="control-label"></label>
                <select asp-for="SpeakerStatus" class="control-label" asp-items="@(new SelectList(@ViewBag.statusTypeList, "Id", "SpeakerStatus"))"></select>
            </div>
        </form>
    </div>
</div>

<div>
    <a asp-action="Index">Back to List</a>
</div>

@section Scripts {
    @{await Html.RenderPartialAsync("_ValidationScriptsPartial");}
}

问题是<select asp-for="SpeakerStatus" class="control-label" asp-items="@(new SelectList(@ViewBag.statusTypeList, "Id", "SpeakerStatus"))"></select>需要一个我没有的 ID,因为我正在创建一个新记录。

我将 @ViewBag.statusTypeList 设置为:

List<SpeakerStatusLookupModel> statusTypeList = new();
            statusTypeList = (from SpeakerStatus in _context.SpeakerStatusLookupModel select SpeakerStatus).ToList();
            statusTypeList.Insert(0, new SpeakerStatusLookupModel { Id = 0, SpeakerStatus = "Select" });
            ViewBag.statusTypeList = statusTypeList;

我发现了问题 - 我在控制器的“编辑”部分中有 @ViewBag.statusTypeList 代码,但在“创建”部分没有,所以当我尝试创建新记录时它是 NULL。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM