簡體   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