{ column-6ren">
gpt4 book ai didi

c# - 尝试使用 ASP.NET MVC 从 Kendo UI Grid 中的子网格重定向时出错

转载 作者:太空宇宙 更新时间:2023-11-03 13:10:54 24 4
gpt4 key购买 nike

@(Html.Kendo().Grid<ClaimTravelCashSelectByApproverId_Result>()
.Name("grid")
.Columns(columns =>
{
columns.Bound(e => e.chkbox)
.HeaderTemplate("<input type='checkbox' id='chkAllClaim'/>")
.ClientTemplate("<input type='checkbox' class='clsClaim'/>")
.HtmlAttributes(new { style = "text-align: center" })
.Filterable(false)
.Width(50);
columns.Bound(e => e.Name)
.Filterable(filterable => filterable.UI("name"))
.Width(150)
.Title("Claim");
columns.Bound(e => e.Description)
.Filterable(false)
.Width(150);
columns.Bound(e => e.Amount)
.Filterable(false)
.Width(100);
columns.Bound(e => e.Status)
.Width(100);
columns.Bound(e => e.FullName)
.Width(150);
columns.Bound(e => e.CreatedDate).ClientTemplate("#= kendo.toString(kendo.parseDate(CreatedDate,'dd/MM/yyyy'), '" + ProjectSession.DateFormat + "') #")
.Width(100);
columns.Template(@<text></text>).ClientTemplate(
@Html.ViewLink("View Comment", "javascript:", null, null, new { datahref = Url.Action("_ViewClaimComment", "Home", new { Data = "#=ClaimId#" }), @class = "clsView" }).ToHtmlString())
.Width(50);

})
.Sortable()
.Pageable()
.Scrollable()
.ClientDetailTemplateId("template")
.HtmlAttributes(new { style = "height:1000px;" })
.Filterable(filterable => filterable
.Extra(false)
.Operators(operators => operators
.ForString(str => str.Clear()
.StartsWith("Starts with")
.IsEqualTo("Is equal to")
.IsNotEqualTo("Is not equal to")
))
)
.DataSource(dataSource => dataSource
.Ajax()
.PageSize(6)
.Read(read => read.Action("claimApproverList", "Approver"))
)
.Events(events => events.DataBound("dataBound")))

<script id="template" type="text/kendo-tmpl">@(Html.Kendo().Grid<ClaimSelectByApproverIdByClaimId_Result>()
.Name("grid_#=ClaimId#")
.Columns(columns =>
{
columns.Bound(o => o.ClaimId).Width(110);
columns.Bound(o => o.ClaimTypeId).Width(110);
columns.Bound(o => o.ClaimTypeName).Width(110);
columns.Bound(o => o.NoOfItems).Width(110);
columns.Template(@<text></text>).ClientTemplate(
@Html.ViewLink("View", "RedirectByClaimTypeName", "Approver", new { Data = "#=ClaimId#" , TypId = "#=ClaimTypeId#" }).ToHtmlString())
.Width(50);
})
.DataSource(dataSource => dataSource
.Ajax()
//.PageSize(10)
.Read(read => read.Action("GetClaimInnerGridByClaimId", "Approver", new { ClaimId = "#=ClaimId#" }))
)
//.Pageable()
//.Sortable()
.ToClientTemplate()
)</script>

/* View comment fro claim*/
$(".clsView").click(function (e) {
e.preventDefault();
e.stopPropagation();
alert($(this).attr("datahref"));
$("#divCommentsdialog").load($(this).attr("datahref")).dialog({
modal: true,
height: 450,
width: 600,
draggable: false,
resizable: false,
dialogClass: 'no-close success-dialog',
title: '@objFieldNameList["Claim"]' + " " + '@objFieldNameList["Comment"]',
close: function (event, ui) {
$(this).dialog('destroy');
$("#divCommentsdialog").empty();
}
});
});




$("#chkAllClaim").click(function () {
$('.clsClaim').prop('checked', $(this).is(':checked'));
});



/* If all checkbox is checked than top checkbox will be checked.*/
$('.clsClaim').click(function () {
if ($('.clsClaim:not(:checked)').length > 0) {
$("#chkAllClaim").prop('checked', false);
}
else {
$("#chkAllClaim").prop('checked', true);
}
});

现在我的问题是:

  1. 当我检查“chkAllClaim”时,Kendo 网格似乎被回发并且未选中复选框(不知道在我的 js 函数之后到底发生了什么)

  2. 当我点击“clsView”类时,它不会转到 js 函数(当我从浏览器插入该函数然后工作时)

  3. 在我的第一个网格中,对于“查看评论”,我得到了“#=ClaimId#”,在第二个网格(子网格)中,我也得到了“#=ClaimId#”,但是当我尝试获取“#=ClaimTypeId#",我遇到了错误:ReferenceError: ClaimTypeId is not defined(到底问题出在哪里?)

我从这里引用:http://demos.telerik.com/aspnet-mvc/grid/hierarchy

最佳答案

只需在 # 之前使用\\作为内部网格绑定(bind)

  @(Html.Kendo().Grid<Uhrs.Domain.Entities.EntityPermission>()
.Name("grid_#=FundUserRoleId#") // make sure the Name is unuque
.Columns(columns =>
{
columns.Bound(p => p.MenuID).Visible(false);
columns.Bound(p => p.MenuName).ClientTemplate("<strong>\\#:MenuName\\#</strong>");
columns.Bound(p => p.MenuStatus).ClientTemplate("<input type='checkbox' \\#: MenuStatus? checked='checked': checked='' \\# class='chkbx' onclick='checkBoxClick(this,#=FundUserRoleId#)' />");


})
.ToolBar(toolbar => toolbar.Save())
.Editable(editable => editable.Mode(GridEditMode.InCell))
.HtmlAttributes(new { style = "width:610px;" })
.DataSource(dataSource =>
dataSource
.Ajax()
.Batch(true)
.ServerOperation(false)
.PageSize(20)
.Model(model =>
{
model.Id(p => p.MenuID);
model.Field(p => p.MenuName).Editable(false);

})
.Events(events => events.Error("error_handler").RequestEnd("onRequestEndChildGrid"))
.Read(read => read.Action("ReadUserPermissions", "Admin", new { linkFundUserId = "#=FundUserRoleId#" }))
.Create(create => create.Action("CreateUserPermissions", "Admin", new { linkFundUserId = "#=FundUserRoleId#" }))
.Update(update => update.Action("UpdateUserPermissions", "Admin", new { linkFundUserId = "#=FundUserRoleId#", roleID = "#=Role.RoleId#" }))
)
.Pageable()
.ToClientTemplate()
)

关于c# - 尝试使用 ASP.NET MVC 从 Kendo UI Grid 中的子网格重定向时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28743900/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com