详解ASP.NET MVC 下拉框的传值的两种方式
更新时间:2019年12月16日 09:03:41 作者:周江霄
这篇文章主要介绍了详解ASP.NET MVC 下拉框的传值的两种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
以前使用WebForm变成时,下拉框传值只需直接在后台绑定代码就可以了。现在我们来看看在MVC中DropDownList是如果和接受从Controller传过来的值的。
第一种:使用DropDownList
控制器代码:
public ActionResult Index()
{
//1.1查询YzSeriesEntity的数据
List<Model.YzSeriesEntity> seriesList = seriesBLL.LoadEnities().ToList();
//1.2将YzSeriesEntity的数据封装到 SelectList中,制定要生成下拉框选项的value和text属性
SelectList selList1 = new SelectList(seriesList, “SerialName”, “SerialName”);
//2.1查询YzDivisionEntity的数据
List<Model.YzDivisionEntity> divisionList = divisionBLL.LoadEnities().ToList();
//2.2讲YzDivisionEntity的数据封装到 SelectList中,制定要生成下拉框选项的value和text属性
SelectList selList2 = new SelectList(divisionList, “DivisionName”, “DivisionName”);
//3.调用Selectlist的As方法,自动生成SelectListItem集合,并存入ViewBag中
ViewBag.selList1 = selList1.AsEnumerable();
ViewBag.selList2 = selList2.AsEnumerable();
return View();
}
视图代码:
<!————– 添加对话框————–>
<div id=”addDiv”>
@using (Ajax.BeginForm(“Add”, new AjaxOptions() { OnSuccess = “afterAdd” }))
{
<table>
<tr>
<td>编号:</td>
<td>
@Html.TextBox(“StaffID”)
</td>
</tr>
<tr>
<td>姓名:</td>
<td>@Html.TextBox(“StaffName”)</td>
</tr>
<tr>
<td>性别:</td>
<td>
<input type=”radio” id=”GenderM” name=”Sex” value=”男” />男
<input type=”radio” id=”GenderF” name=”Sex” value=”女” checked />女
</td>
</tr>
<tr>
<td>所在系列:</td>
<td>
@Html.DropDownList(“SerialName”, ViewBag.selList1 as IEnumerable<SelectListItem>)
</td>
</tr>
<tr>
<td>科室或年级组:</td>
<td>
@Html.DropDownList(“DivisionName”, ViewBag.selList2 as IEnumerable<SelectListItem>)
</td>
</tr>
<tr>
<td>任课学科:</td>
<td>
@Html.TextBox(“Subjects”)
</td>
</tr>
<tr>
<td>聘任日期:</td>
<td>
@Html.TextBox(“EngageDate”)
</td>
</tr>
<tr>
<td>参加工作日期:</td>
<td>
@Html.TextBox(“WorkDate”)
</td>
</tr>
<tr>
<td>职称:</td>
<td>
@Html.TextBox(“jobQualification”)
</td>
</tr>
<tr>
<td>身份证号:</td>
<td>
@Html.TextBox(“IdentityCard”)
</td>
</tr>
</table>
}
</div>
效果显示:
第二种:使用<select></select>
视图代码:
<!–选择权重–>
<div>
<span>@Html.Label(“请选择权重:”)</span>
<span>
<select id=”cc” class=”easyui-combobox” name=”dept”
data-options=”valueField:’ID’,textField:’Weight’,url:’/SettingEvaluation/ListOption'” />
</span>
</div>
控制器代码:
//下拉框对应的列表
public ActionResult ListOption()
{
//2.1.查询出weight实体,并将其转成DTO类型
List<Model.DTO.YzWeightEntityDTO> weightList =
weightBLL.LoadEnities().ToList().Select(s => s.ToDto()).ToList();
//2.2返回json
return Json(weightList, JsonRequestBehavior.AllowGet);
}
效果显示:
总结:
两种传值方式的比较:
第一种是控制器通过ViewBag传值,前台通过@Html.DropDownList接收;第二种是通过Json传值,前台通过url绑定valueField和textField的值来获取数据。两者没有什么太大的不同,但是由于传值使用<select></select>接收的,使用的是HTML标签,所以还可以用来绑定其他的js事件,所以如果有功能需要的话,后者要比前者灵活些。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持华域联盟。
您可能感兴趣的文章:详解ASP.NET MVC之下拉框绑定四种方式ASP.NET MVC下拉框联动实例解析asp.net mvc下拉框Html.DropDownList 和DropDownListFor的常用方法
ASP.NET
MVC
下拉框
传值
相关文章
ASP.NET页面按钮单击事件失效的解决方法按钮的单击事件不起作用了,加了断点之后发现根本没有触发该事件,下面有个不错的解决方法,大家可以参考下 2014-02-02
Asp.net实现无刷新调用后台实体类数据并以Json格式返回本文主要分享了Asp.net实现无刷新调用后台实体类数据并以Json格式返回的具体实例方法,具有一定的参考价值,有需要的朋友可以看下 2016-12-12
.net中as和is之间的区别分析.net中as和is之间的区别分析,需要的朋友可以参考一下 2013-05-05
三步将Asp.Net页面输出到EXCEL里利用ASP.NET输出指定内容的WORD、EXCEL、TXT、HTM等类型的文档很容易的,下面为大家简单介绍下,感兴趣的朋友可以参考参考 2014-05-05
.NET异步编程总结—-四种实现模式代码总结本篇文章主要介绍了.NET异步编程总结—-四种实现模式,详细的介绍了每种方法的实现和实例,具有一定的参考价值,有兴趣的可以了解一下。
2016-12-12
IdentityServer4 QuckStart 授权与自定义Claims的问题这篇文章主要介绍了IdentityServer4 QuckStart 授权与自定义Claims的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下 2020-04-04
将文件上传、下载(以二进制流保存到数据库)实现代码将文件以二进制流的格式写入数据库:首先获得文件路径,然后将文件以二进制读出保存在一个二进制数组中具体请祥看本文,希望对你有所帮助 2013-05-05
Jexus部署.Net Core项目这篇文章主要为大家详细介绍了Jexus部署.Net Core项目的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 2017-06-06
ADO.NET制做一个登录案例这篇文章主要为大家介绍了ADO.NET制做一个登录案例的详细过程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 2016-07-07
asp.net中session的原理及应用详解Session是一种Web会话中的常用状态之一,Session提供了一种把信息保存在服务器内存中的方式。他能储存任何数据类型,包含自定义对象,本文将详细介绍asp.net中session的原理及应用,需要的朋友可以参考下 2012-11-11
最新评论

评论(0)