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.
热点阅读
