ошибка "System.ArgumentNullException: 'Значение не может быть нулевым. Имя параметра: коллекция'" "ASP: NET MVC C# Visual Studio 2017 dataTables - PullRequest
0 голосов
/ 01 апреля 2020

У меня есть dataTable, в котором у меня есть представление для редактирования данных.

Это работает, но не когда я добавляю в свою модель некоторые требования, такие как:

    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: 'Значение не может быть нулевым.
Имя параметра: collection'

при отладке в моем представлении в одном списке dropDown, который не является де Данные я поставил требования, поэтому я не понимаю, почему эта ошибка и как ее решить.

Строка с ошибкой:

@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 ();
    }

1 Ответ

0 голосов
/ 02 апреля 2020

Я исправил это добавлением MainLanguagelist(); в моем методе http post.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...