开发者

Simple DropDownListFor in MVC2?

I've got a table that stores a True/False value as a sqlserver bit field (Featured). First, is there a better way to generate a dropdown list for this other than manually?

Second, here's what I've go开发者_StackOverflow中文版t so far which works but does not add selected="selected" to any items in the DDL.

Edit 1: I've updated this example according to the answer suggested and it results in a run-time error :( Edit 2: Using it like a function works (with and without the cast) but selected="selected" is still not being added.

Model:

//
// View models
public class SpotlightFormViewModel
{

    // props
    public Spotlight Spotlight { get; private set; }
    public SelectList FeaturedMenu { get; private set; }

    static IDictionary<string, int> feature = new Dictionary<string, int>(){
        {"True", 1},
        {"False", 0},
    };

    public IEnumerable<SelectListItem> FeaturedChoices(Spotlight spotlight)
    {
        return feature.Select(f => new SelectListItem
        {
            Text = f.Key,
            Value = f.Value.ToString(),
            Selected = spotlight.Featured,
        });
    }

    // constr
    public SpotlightFormViewModel(Spotlight spotlight)
    {
        Spotlight = spotlight;
        FeaturedMenu = new SelectList(FeaturedChoices(spotlight));
    }
}

Controller:

    public ActionResult Edit(int id)
    {
        Spotlight spotlight = spotlightRepository.GetSpotlight(id);

        return View(new SpotlightFormViewModel(spotlight));
    }

View:

        <div class="editor-label">
            <%: Html.LabelFor(model => model.Spotlight.Featured) %>
        </div>
        <div class="editor-field">
            <%: Html.DropDownListFor(model => model.FeaturedMenu, Model.FeaturedChoices(Model.Spotlight))%>
            <%: Html.ValidationMessageFor(model => model.Spotlight.Featured) %>
        </div>


I use the dropdowlist in the same that you do. But in your case you could simply use some radio buttons:

 <%: Html.Label("True") %>
 <%: Html.RadioButtonFor(model => model.FeaturedMenu, "1") %>

 <%: Html.Label("False") %>
 <%: Html.RadioButtonFor(model => model.FeaturedMenu, "0") %>

Secondly, you talked about the "selected" value, but you did not use it in "public IEnumerable FeaturedChoices", you could add the selected value like this:

return feature.Select(f => new SelectListItem
{
    Text = f.Key,
    Value = f.Value.ToString(),
    Selected = false
});


I finally got this working. Even though my syntax & logic was correct when I was passing variables to public IEnumerable FeaturedChoices(Spotlight spotlight) it wouldn't work regardless, even if I explicitly marked Selected = true. If someone could answer why that is so I would appreciate it

The only way selected="selected" was correctly applied is if I made FeaturedChoices a property with a getter. Full working code below

View model:

//
// View models
public class SpotlightFormViewModel
{

    // props
    public Spotlight Spotlight { get; private set; }
    public SelectList FeaturedMenu { get; private set; }

    static IDictionary<string, int> feature = new Dictionary<string, int>(){
        {"True", 1},
        {"False", 0},
    };

    public IEnumerable<SelectListItem> FeaturedChoices
    {
        get
        {                
            return feature.Select(f => new SelectListItem
            {
                Text = f.Key,
                Value = f.Value.ToString(),
                Selected = IsSelected(this.Spotlight.Featured, f.Key)
            });
        }
    }

    private bool IsSelected(bool featured, string val)
    {
        bool result = false;

        if (String.Compare(val, "True") == 0 && featured)
            result = true;
        else if (String.Compare(val, "False") == 0 && !featured)
            result = true;

        return result;
    }

    // constr
    public SpotlightFormViewModel(Spotlight spotlight)
    {
        Spotlight = spotlight;
    }
}

Controller:

    public ActionResult Edit(int id)
    {
        Spotlight spotlight = spotlightRepository.GetSpotlight(id);

        return View(new SpotlightFormViewModel(spotlight));
    }

View:

        <div class="editor-label">
            <%: Html.LabelFor(model => model.Spotlight.Featured) %>
        </div>
        <div class="editor-field">
            <%: Html.DropDownListFor(model => model.FeaturedMenu, Model.FeaturedChoices)%>
            <%: Html.ValidationMessageFor(model => model.Spotlight.Featured) %>
        </div>
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜