Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

ASP.NET Core : Tag helper "select" is empty

I need to have a view with select element. I have the following VM class:

public class EditTicketVM
{
    public EditTicketVM()
    {
        Statuses = new SelectList(new List<SelectListItem>{
            new SelectListItem("Open", "open"),
            new SelectListItem("Pending", "pending"),
            new SelectListItem("Hold", "hold"),
            new SelectListItem("Solved", "solved"),
            new SelectListItem("Closed", "closed"),
        });

    }

    public string Description { get; set; }
    public string Subject { get; set; }
    public string Status { get; set; }

    public SelectList Statuses { get; set; }
}

and select element on page:

<select asp-for="Status" class="form-control" asp-items="Model.Statuses" />

But on result page this element is empty:

enter image description here

what is incorrect in my code?

like image 479
Oleg Sh Avatar asked Aug 31 '25 00:08

Oleg Sh


1 Answers

I have tested your code on my side. Problem is in your select tag. You are using self closing select tag. This will not work. Write your select tag as follows:

<select asp-for="Status" class="form-control" asp-items="Model.Statuses">
   <option value="">Select Status</option>
</select>

You have also problem in your SelectList initialization. The way you have initialized SelectList would not work. Initialize your SelectList as follows:

public EditTicketVM()
{
   Statuses = new SelectList(new List<SelectListItem> {
       new SelectListItem(){Text = "Open", Value = "open"},
       new SelectListItem(){Text = "Pending", Value = "pending"},
       new SelectListItem(){Text = "Hold", Value = "hold"},
       new SelectListItem(){Text = "Solved", Value = "solved"},
       new SelectListItem(){Text = "Closed", Value = "closed"},
    },"Value","Text");
}
like image 197
TanvirArjel Avatar answered Sep 02 '25 13:09

TanvirArjel