asp.net-mvc – MVC 3布局页面,Razor模板和下拉列表
发布时间:2020-07-20 16:13:00 所属栏目:asp.Net 来源:互联网
导读:我想在我的网站的所有页面包括一个下拉列表的年。我假设一个好的地方放这个逻辑是在布局页面(_layout.cshtml)。如果用户更改我想要更改年会话(ModelBinder)的年份,也要更改。这是很容易做ASP.NET web表单,但似乎几乎不可能做到在MVC。我试着没有运气的局部
我想在我的网站的所有页面包括一个下拉列表的年。我假设一个好的地方放这个逻辑是在布局页面(_layout.cshtml)。如果用户更改我想要更改年会话(ModelBinder)的年份,也要更改。这是很容易做ASP.NET web表单,但似乎几乎不可能做到在MVC。我试着没有运气的局部视图。任何人有任何想法? 解决方法像往常一样,你可以从定义视图模型开始:public class YearsViewModel { public string Year { get; set; } public IEnumerable<SelectListItem> Years { get { return new SelectList( Enumerable.Range(1900,112) .OrderByDescending(year => year) .Select(year => new SelectListItem { Value = year.ToString(),Text = year.ToString() } ),"Value","Text"); } } } 然后一个控制器: public class YearsController : Controller { public ActionResult Index() { return View(new YearsViewModel()); } [HttpPost] public ActionResult Index(int year) { // TODO: do something with the selected year return new EmptyResult(); } } 以及索引操作的相应视图: @model SomeAppName.Models.YearsViewModel @{ Layout = null; } @Html.DropDownListFor(x => x.Year,Model.Years) 最后在你的_Layout.cshtml里面你可以使用这个控制器: <div id="selectyear">@Html.Action("index","years")</div> 并附加相应的脚本,当值发生更改时,将发送AJAX请求: $(function () { $('#selectyear select').change(function () { $.post('@Url.Action("index","years")',{ year: $(this).val() },function (result) { }); }); }); (编辑:鲜蔬坊站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- asp.net-mvc-3 – 将数组传递给RouteValues,并将
- 使用System.Net.Mail中的SMTP发送邮件(带附件)
- asp.net-mvc – 什么是强类型的视图在ASP.NET MV
- Jquery+ajax请求data显示在GridView上(asp.net)
- asp.net 使用驻留在页面中的Cache缓存常用可定时
- asp.net错误表单不能嵌套在元素表单中?
- asp.net-mvc – Url.Action如何从模型中添加参数
- asp.net-mvc – 是否有一个ASP MVC与JSTL标签等效
- 是否有WPF的母版页(如asp.net)的概念?
- asp.net-web-api – Web Api:找不到System.Net.
热点阅读