如何在为 Kendo 网格显示弹出编辑器 window 之前获得确认?
How to get confirmation before displaying the popup editor window for Kendo grid?
当用户点击编辑命令时,我想仅在用户确认后显示弹出式编辑器window。实际上,我正在编辑器中显示一份报告,我想在显示这份报告之前得到用户的确认。
我已经尝试了 events.Edit("onGridEdit") 然后在 onGridEdit(e) javascript 函数中尝试如下:
if (!confirm('Are you sure you want to buy this report ')) {
e.preventDefault();
}
但它不起作用。它会显示确认对话框,但也会打开编辑器 window。
有什么建议吗?
我暂时会在这个答案的中途见到你。
以下示例使用绑定到按钮点击事件的 自定义命令 和 闭包 window.wrapper.
var sharedDataSource = new kendo.data.DataSource(
{
pageSize: 20,
data: [
{"id": 0, "first" : "George", "last" : "Washingon", "ATK" : 9000, "DEF" : 500},
{"id": 1, "first" : "John", "last" : "Adams", "ATK" : 50, "DEF" : 5000},
{"id": 2, "first" : "Thomas", "last" : "Jefferson", "ATK" : 100, "DEF" : 5000}
],
autoSync: true,
schema: {
model: {
id: "id",
fields: {
id: { editable: false, nullable: false },
first: { validation: { required: true } },
last: { validation: { required: true } },
ATK: { type: "number", validation: { required: true, min: 1}},
DEF: { type: "number", validation: { required: true, min: 1}}
}
}
}
});
var grid = $("#grid").kendoGrid({
dataSource: sharedDataSource,
pageable: true,
height: 550,
editable: "inline",
columns: [
{ field: "first", title: "First"},
{ field: "last", title: "Last"},
{ field: "ATK", title: "Attack"},
{ field: "DEF", title: "Defense"},
{ command: { text: "View Details", click: showDetails }, title: " ", width: "180px" }
]
});
var wnd = $("#details").kendoWindow({
title: "Customer Details",
modal: true,
visible: false,
resizable: false,
width: 300
}).data("kendoWindow");
var detailsTemplate = kendo.template($("#template").html());
function showDetails(eArg) {
console.clear();
eArg.preventDefault();
var dataItem = this.dataItem($(eArg.currentTarget).closest("tr"));
console.log(dataItem);
dataItem._self = JSON.stringify(dataItem);
wnd.content(detailsTemplate(dataItem));
wnd.wrapper.find("button.btn-confirm").click(confirmed.bind(null, wnd));
wnd.wrapper.find("button.btn-cancel").click(cancel.bind(null, wnd));
wnd.center().open();
function confirmed(e)
{
console.log("Confirmed");
wnd.close();
console.log(eArg);
console.log(e);
console.log(grid);
console.log(dataItem.parent());
dataItem._events.change[0](dataItem);
}
function cancel(e)
{
console.log("Cancel");
wnd.close();
}
}
#details-container
{
padding: 10px;
background-color:blue;
}
#details-container h2
{
margin: 0;
}
#details-container
{
color: #8c8c8c;
}
#details-container dt
{
margin:0;
display: inline;
}
.k-i-close {background-color:white;content: 'X'};
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="http://cdn.kendostatic.com/2014.1.318/js/kendo.all.min.js"></script>
<link href="http://cdn.kendostatic.com/2014.1.318/styles/kendo.common.min.css" rel="Stylesheet" />
<div id="grid"></div>
<div id="details"></div>
<script type="text/x-kendo-template" id="template">
<div id="details-container">
<h2>#= first # #= last #</h2>
<dl>
<dt>Attack: #= ATK #</dt>
<dt>Defense: #= DEF #</dt>
</dl>
<button class="btn-confirm">Confirm</button>
<button class="btn-cancel">Confirm</button>
</div>
</script>
当用户点击编辑命令时,我想仅在用户确认后显示弹出式编辑器window。实际上,我正在编辑器中显示一份报告,我想在显示这份报告之前得到用户的确认。
我已经尝试了 events.Edit("onGridEdit") 然后在 onGridEdit(e) javascript 函数中尝试如下:
if (!confirm('Are you sure you want to buy this report ')) {
e.preventDefault();
}
但它不起作用。它会显示确认对话框,但也会打开编辑器 window。
有什么建议吗?
我暂时会在这个答案的中途见到你。
以下示例使用绑定到按钮点击事件的 自定义命令 和 闭包 window.wrapper.
var sharedDataSource = new kendo.data.DataSource(
{
pageSize: 20,
data: [
{"id": 0, "first" : "George", "last" : "Washingon", "ATK" : 9000, "DEF" : 500},
{"id": 1, "first" : "John", "last" : "Adams", "ATK" : 50, "DEF" : 5000},
{"id": 2, "first" : "Thomas", "last" : "Jefferson", "ATK" : 100, "DEF" : 5000}
],
autoSync: true,
schema: {
model: {
id: "id",
fields: {
id: { editable: false, nullable: false },
first: { validation: { required: true } },
last: { validation: { required: true } },
ATK: { type: "number", validation: { required: true, min: 1}},
DEF: { type: "number", validation: { required: true, min: 1}}
}
}
}
});
var grid = $("#grid").kendoGrid({
dataSource: sharedDataSource,
pageable: true,
height: 550,
editable: "inline",
columns: [
{ field: "first", title: "First"},
{ field: "last", title: "Last"},
{ field: "ATK", title: "Attack"},
{ field: "DEF", title: "Defense"},
{ command: { text: "View Details", click: showDetails }, title: " ", width: "180px" }
]
});
var wnd = $("#details").kendoWindow({
title: "Customer Details",
modal: true,
visible: false,
resizable: false,
width: 300
}).data("kendoWindow");
var detailsTemplate = kendo.template($("#template").html());
function showDetails(eArg) {
console.clear();
eArg.preventDefault();
var dataItem = this.dataItem($(eArg.currentTarget).closest("tr"));
console.log(dataItem);
dataItem._self = JSON.stringify(dataItem);
wnd.content(detailsTemplate(dataItem));
wnd.wrapper.find("button.btn-confirm").click(confirmed.bind(null, wnd));
wnd.wrapper.find("button.btn-cancel").click(cancel.bind(null, wnd));
wnd.center().open();
function confirmed(e)
{
console.log("Confirmed");
wnd.close();
console.log(eArg);
console.log(e);
console.log(grid);
console.log(dataItem.parent());
dataItem._events.change[0](dataItem);
}
function cancel(e)
{
console.log("Cancel");
wnd.close();
}
}
#details-container
{
padding: 10px;
background-color:blue;
}
#details-container h2
{
margin: 0;
}
#details-container
{
color: #8c8c8c;
}
#details-container dt
{
margin:0;
display: inline;
}
.k-i-close {background-color:white;content: 'X'};
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="http://cdn.kendostatic.com/2014.1.318/js/kendo.all.min.js"></script>
<link href="http://cdn.kendostatic.com/2014.1.318/styles/kendo.common.min.css" rel="Stylesheet" />
<div id="grid"></div>
<div id="details"></div>
<script type="text/x-kendo-template" id="template">
<div id="details-container">
<h2>#= first # #= last #</h2>
<dl>
<dt>Attack: #= ATK #</dt>
<dt>Defense: #= DEF #</dt>
</dl>
<button class="btn-confirm">Confirm</button>
<button class="btn-cancel">Confirm</button>
</div>
</script>