asp.net – 部分视图呈现按钮点击
发布时间:2021-01-11 15:04:56 所属栏目:asp.Net 来源:互联网
导读:我有索引视图: @using System.Web.Mvc.Html@model MsmqTestApp.Models.MsmqData!DOCTYPE htmlhtmlhead script src=@Url.Content(~/Scripts/jquery.unobtrusive-ajax.min.js) type=text/javascript
|
我有索引视图: @using System.Web.Mvc.Html
@model MsmqTestApp.Models.MsmqData
<!DOCTYPE html>
<html>
<head>
<script src="@Url.Content("~/Scripts/jquery.unobtrusive-ajax.min.js")" type="text/javascript"></script>
<meta name="viewport" content="width=device-width" />
<title>MsmqTest</title>
</head>
<body>
<div>
<input type="submit" id="btnBuy" value="Buy" onclick="location.href='@Url.Action("BuyItem","MsmqTest",new { area = "Msmq" })'" />
<input type="submit" id="btnSell" value="Sell" onclick="location.href='@Url.Action("SellItem",new { area = "Msmq" })'" />
</div>
<div id="msmqpartial">
@{Html.RenderPartial("Partial1",Model); }
</div>
</body>
</html>
和部分: @using System.Web.Mvc.Html
@model MsmqTestApp.Models.MsmqData
<p>
Items to buy
@foreach (var item in Model.ItemsToBuy)
{
<tr>
<td>@Html.DisplayFor(model => item)
</td>
</tr>
}
</p>
<p>
<a>Items Selled</a>
@foreach (var item in Model.ItemsSelled)
{
<tr>
<td>@Html.DisplayFor(model => item)
</td>
</tr>
}
</p>
和控制器: public class MsmqTestController : Controller
{
public MsmqData data = new MsmqData();
public ActionResult Index()
{
return View(data);
}
public ActionResult BuyItem()
{
PushIntoQueue();
ViewBag.DataBuyCount = data.ItemsToBuy.Count;
return PartialView("Partial1",data);
}
}
如何做到这一点,当我点击一个按钮只是部分视图渲染,现在控制器要移动我到BuyItem视图; / 解决方法首先要做的是引用jQuery.现在你只引用了jquery.unobtrusive-ajax.min.js,但这个脚本依赖于jQuery,所以不要忘记在它之前包括:<script src="@Url.Content("~/Scripts/jquery.jquery-1.5.1.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.unobtrusive-ajax.min.js")" type="text/javascript"></script>
现在您的问题:您应该使用提交按钮与HTML表单.在你的例子中,你没有一个表单,所以在语义上更正确的是使用普通按钮: <input type="button" value="Buy" data-url="@Url.Action("BuyItem",new { area = "Msmq" })" />
<input type="button" value="Sell" data-url="@Url.Action("SellItem",new { area = "Msmq" })" />
然后在单独的javascript文件中通过订阅.click()事件AJAXify这些按钮: $(function() {
$(':button').click(function() {
$.ajax({
url: $(this).data('url'),type: 'GET',cache: false,success: function(result) {
$('#msmqpartial').html(result);
}
});
return false;
});
});
或者如果您想依靠Microsoft不引人注目的框架,您可以使用AJAX actionlinks: @Ajax.ActionLink("Buy","BuyItem",new { area = "Msmq" },new AjaxOptions { UpdateTargetId = "msmqpartial" })
@Ajax.ActionLink("Sell","SellItem",new AjaxOptions { UpdateTargetId = "msmqpartial" })
如果您想要按钮而不是锚点,您可以使用AJAX表单: @using (Ajax.BeginForm("BuyItem",new AjaxOptions { UpdateTargetId = "msmqpartial" }))
{
<button type="submit">Buy</button>
}
@using (Ajax.BeginForm("SellItem",new AjaxOptions { UpdateTargetId = "msmqpartial" }))
{
<button type="submit">Sell</button>
}
从我可以看到,您已经将jquery.unobtrusive-ajax.min.js脚本包含在您的页面中,这应该是正常的. (编辑:岳阳站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- asp.net – 如何在页面加载时以“添加新”模式进行编程设置
- asp.net – Request.Browser.Platform不返回iPad,OSX或Wind
- asp.net-mvc-3 – 为什么两个类,视图模型和域模型?
- asp.net代码中修改web.config节点的具体方法
- asp.net-mvc – asp.net mvc – string或int的路由(即/ typ
- 实体框架 – WebApi OData:$filter’any’或’all’查询不
- asp.net下文件上传和文件删除的代码
- ASP.NET VNext类库System.Runtime.Serialization
- asp.net-mvc – 无法更改关系,因为一个或多个外键属性在MVC
- 在IIS / ASP.Net中的.NET 1.1应用程序中创建.NET 3.0子应用
推荐文章
站长推荐
- asp.net-mvc – 在部署MVC 2 Web应用程序时要绝对
- asp.net-mvc – 命名约定 – 控制器的一个规则,没
- asp.net – 我可以重新发布或携带POST数据(如果是
- asp.net-mvc – 在ClaimsIdentity上,BootstrapCo
- [转]谈谈技术原则,技术学习方法,代码阅读及其它
- asp.net – 有没有比升级到Visual Studio 2010 U
- asp.net – ASP MVC – 默认的HTTP标头有任何常量
- NHibernate中关于Inverse的理解和使用
- asp.net确保javascript只加载一次
- 如何使用Fluent Nhibernate中的Automapping进行O
热点阅读
