我在一个不同的局部视图中有2个WebGrids,显示在View页面上。一切正常,但是当我在WebGrid上进行排序或分页时,它不会通过ajax进行更新。我做错了什么?
PartialView1 :
<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<IEnumerable<CRMEvent.Models.CRM.DatabaseEntities.CRM_Request>>" %>
<%
var grid1var = new WebGrid(source: Model, defaultSort: "Id", fieldNamePrefix: "grid1", canSort: true, ajaxUpdateContainerId: "Div1", canPage: true, rowsPerPage: 5);%>
<div id="Div1">
<%=grid1var.GetHtml(htmlAttributes: new { id = "grid1" }, tableStyle: "GridTable", headerStyle: "GridHeader", footerStyle: "GridFooter",
columns: grid1var.Columns(
grid1var.Column(columnName: "Id", header: "ID", canSort: true),
grid1var.Column(columnName: "Request_For_Id", header: "Request For", canSort: true),
grid1var.Column(columnName: "Date_Created", header: "Date", canSort: true, format: item => item.Date_Created.ToString("dd-MM-yyyy"))
))%>
</div>
PartialView2
<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<IEnumerable<CRMEvent.Models.CRM.DatabaseEntities.CRM_Request>>" %>
<%
var grid2var = new WebGrid(source: Model, defaultSort: "Id", fieldNamePrefix: "grid2", canSort: true, ajaxUpdateContainerId: "Div2", canPage: true, rowsPerPage: 5);%>
<div id="Div2">
<%=grid2var.GetHtml(htmlAttributes: new { id = "grid2" }, tableStyle: "GridTable", headerStyle: "GridHeader", footerStyle: "GridFooter",
columns: grid2var.Columns(
grid2var.Column(columnName: "Id", header: "ID", canSort: true),
grid2var.Column(columnName: "Request_For_Id", header: "Request For", canSort: true),
grid2var.Column(columnName: "Date_Created", header: "Date", canSort: true, format: item => item.Date_Created.ToString("dd-MM-yyyy"))
))%>
</div>
的MainPage:
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<CRMEvent.Models.CRM.DatabaseEntities.CRM_Request>" %>
<asp:Content ID="Head" ContentPlaceHolderID="HeadContent" runat="server">
<link href="../../Content/Styles/Dashboard.css" rel="stylesheet" type="text/css" />
<script src="../../Scripts/jquery.validate.unobtrusive.min.js" type="text/javascript"></script>
</asp:Content>
<asp:Content ID="Main" ContentPlaceHolderID="MainContent" runat="server">
<%using (Html.BeginForm("Action", "Dashboard", FormMethod.Post)){ %>
<div id="MainDashboardDiv">
<div class="LiveTile">
<div id="PriorityDiv1">
<%Html.RenderAction("RecentRequests", Model); %>
</div> <!--End of PriorityDiv1 -->
<div id="PriorityDiv2">
<%Html.RenderAction("PriorityRequests", Model); %>
</div> <!--End of PriorityDiv2 -->
</div> <!--End of LiveTile -->
</div><!--End of MainDashboardDiv -->
<%} %>
</asp:Content>
主页HEAD标记内容:
<head id="head" runat="server">
<title><asp:ContentPlaceHolder ID="TitleContent" runat="server" /></title>
<link href="../../Content/Site.css" rel="stylesheet" type="text/css" />
<script src="<%: Url.Content("~/Scripts/jquery-1.9.1.min.js") %>" type="text/javascript"></script>
<script src="<%: Url.Content("~/Scripts/modernizr-1.7.min.js") %>" type="text/javascript"></script>
<asp:ContentPlaceholder ID="HeadContent" runat="server">
</asp:ContentPlaceholder>
<link href="../../Content/menu.css" rel="stylesheet" type="text/css" />
<script src="../../Scripts/jquery.js" type="text/javascript"></script>
<script src="../../Scripts/menu.js" type="text/javascript"></script>
</head>
当我通过firebug检查控制台时,我在进行排序和分页时看到了错误: 错误是:
TypeError:$(...)。parent(...)。delegate不是函数
代码:
$(containerId).parent()。delegate(containerId +' a [data-swhglnk =“true”]','click',function()
上面的代码是由WebGrid动态生成的。我不是在写它。
答案 0 :(得分:1)
如果webgrid
包括jQuery,并且您正在引用jQuery,那么jQuery定义了两次。这可以解释你的错误:
$(containerId).parent().delegate(containerId + ' a[data-swhglnk="true"]', 'click', function()
禁用网页中的链接,它应该可以使用。如果您需要使用jQuery 1.9+并且webgrid
使用旧版本的jQuery,则将其替换为更新版本。
如果webgrid
与jQuery 1.9+不兼容,可能会出现错误,然后发表评论以获得更多帮助。
提示:检查最终生成的多个jQuery包含的HTML。
答案 1 :(得分:1)
try this
$(containerId).parent.delegate(containerId + ' a[data-swhglnk="true"]', 'click', function()
答案 2 :(得分:1)
好吧我知道这个问题,但我是新人。所以这需要我一点点。问题是您的部分视图导致您的事件监听器在排序和传播上停止侦听。如果您尝试使用Jquery设置多页表,您将遇到同样的问题;当您切换浏览器将断开连接的页面时。这种情况在Jquery内部发生,并带来其他好处;它是出于安全原因而做的,所以不要改变它。所以现在有两种方法可以解决这个问题。第一种是每次需要连接时通过回调重新连接,第二种是将听力责任下放到子类。
我会用答案发布这些例子,但是赏金差不多了。所以我希望有机会,无论哪种方式,如果你有兴趣让我知道,我会很快得到代码。