加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net-mvc-3 – html.dropdownlist MVC3混乱

发布时间:2020-12-16 04:11:13 所属栏目:asp.Net 来源:网络整理
导读:这对我有用,但我如何使用html.dropdownlist做同样的事情? 请注意,传递的值不是向用户显示的值. @model IEnumerableMVR.Models.ViewIndividualh2Level1/h2 select @foreach (var item in Model) { option value="@item.Case_Number"@item.Patient_Lastname,@
这对我有用,但我如何使用html.dropdownlist做同样的事情?

请注意,传递的值不是向用户显示的值.

@model IEnumerable<MVR.Models.ViewIndividual>

<h2>Level1</h2>    
<select>
        @foreach (var item in Model) {
        <option value="@item.Case_Number">@item.Patient_Lastname,@item.Patient_Firstname
        </option>
}
</select>

解决方法

与ASP.NET MVC应用程序一样,您首先要定义视图模型:
public class MyViewModel
{
    public string SelectedIndividual { get; set; }
    public SelectList Individuals { get; set; }
}

然后你编写一个控制器动作,从一些数据源或其他东西填充这个视图模型:

public ActionResult Index()
{
    // TODO : fetch those from your repository
    var values = new[]
    {
        new { Value = "1",Text = "item 1" },new { Value = "2",Text = "item 2" },new { Value = "3",Text = "item 3" },};

    var model = new MyViewModel
    {
        Individuals = new SelectList(values,"Value","Text")
    };
    return View(model);
}

最后你有一个使用强类型助手的强类型视图:

@model MyViewModel
@Html.DropDownListFor(
    x => x.SelectedIndividual,Model.Individuals
)

这就是说,因为我发现你没有在你的应用程序中使用任何视图模型,你总是可以尝试以下丑陋(不推荐,这需要你自己承担风险):

@model IEnumerable<MVR.Models.ViewIndividual>

<h2>Level1</h2>
@Html.DropDownList(
    "SelectedIndividual",new SelectList(
        Model.Select(
            x => new { 
                Value = x.Case_Number,Text = string.Format(
                    "{0},{1}",x.Patient_Lastname,x.Patient_Firstname
                ) 
            }
        ),"Text"
    )
)

当然,这种色情内容不是我建议在视图中写的东西,我也不会向我最坏的敌人推荐.

结论:在ASP.NET MVC应用程序中,您应始终使用视图模型和强类型帮助程序的强类型视图(请参阅我的答案的第一部分).

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读