繁体   English   中英

错误“System.ArgumentNullException:'值不能为空。参数名称:集合'”“ASP:NET MVC C# Visual Studio 2017 数据表

[英]error "System.ArgumentNullException: 'Value cannot be null. Parameter name: collection' "" ASP:NET MVC C# Visual Studio 2017 dataTables

我有一个数据表,我可以在其中编辑数据。

它有效,但当我在模型中添加一些要求时无效,例如:

    public class ModelTemplateEmail
{      
    [Display(Name = "EmailId")]
    public int EmailId { get; set; }
    [Display(Name = "UserName")][StringLength(20, ErrorMessage = "Do not enter more than 20 characters")]
    [MaxLength(20)]
    [Required(ErrorMessage = "Please enter a User name")]
    public string userName { get; set; }
    [Display(Name = "Email")]
    [DataType(DataType.EmailAddress)]
    [Required(ErrorMessage = "Please enter an Email")]
    [RegularExpression(@"^\w+([-+.']\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$", ErrorMessage = "Email is not valid.")] 
    public string Email { get; set; }
    [Display(Name = "Title")]      
    public string Title { get; set; }
    [Display(Name = "Description")]
    public string description { get; set; }    
    public List<ModelTemplateEmail> EmailDataList { get; set; }     

    [Key]
    public int languageID { get; set; }
    [Display(Name = "Language")]
    public string MainLanguage { get; set; }

}

我收到一个错误

System.ArgumentNullException: '值不能为空。
参数名称:集合'

在我的视图中的一个下拉列表中调试时,这不是 de data 我提出了要求,所以我不明白为什么会出现这个错误以及如何解决它。

有错误的字符串是:

@Html.DropDownListFor(model => model.languageID, new List<SelectListItem>(ViewBag.MainLanguage), new { @class = "form-control" })

我的 DropDwnList 的控制器是:

public void MainLanguagelist()
    {
        var sqlstring = string.Format("SELECT [languageID], [MainLanguage] FROM [dbo].[Language]");

        var myConnection = getconection();
        SqlCommand myCommand = new SqlCommand(sqlstring, myConnection);
        myCommand.ExecuteNonQuery();
        SqlDataAdapter Language = new SqlDataAdapter(myCommand);
        DataSet setLanguageData = new DataSet();
        Language.Fill(setLanguageData);
        ViewBag.MainLanguageList = setLanguageData.Tables[0];
        List<SelectListItem> MainLanguageList = new List<SelectListItem>();

        foreach (DataRow MainLanguage in ViewBag.MainLanguageList.Rows)
        {
           MainLanguageList.Add(new SelectListItem {Text = @MainLanguage["MainLanguage"].ToString(),
           Value = @MainLanguage["languageID"].ToString()});
        }

        ViewBag.MainLanguage = MainLanguageList;


        try
        {             
            myConnection.Close();
        }
        catch (Exception e)
        {
            Console.WriteLine(e.ToString());
        }

    }

行动结果:

    public ActionResult EditData(int EmailId, string userName, string Title, string Email, string description, int languageID)
    {

            ModelTemplateEmail Editdata = new ModelTemplateEmail
            {
              EmailId = EmailId, userName = userName, Email = Email, description = description,
              Title = Title, languageID = languageID
            };

             MainLanguagelist();

        return View(Editdata);
    }

    [HttpPost]
    [ValidateAntiForgeryToken]
    public ActionResult EditData(ModelTemplateEmail modelEmail)
    {
        UpdateDataBase(modelEmail.EmailId, modelEmail.userName, modelEmail.Title, 
                       modelEmail.Email,modelEmail.description, modelEmail.languageID);


        return View ();
    }

我修复了它添加MainLanguagelist(); 在我的 http post 方法中。

暂无
暂无

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

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