单击网格数据时弹出kendo窗口

时间:2015-04-16 12:59:48

标签: kendo-ui kendo-grid kendo-asp.net-mvc

我在项目中为10个产品创建了一个kendo网格。当我点击kendo网格中显示的产品名称时,我希望弹出包含产品详细信息的kendo窗口。

我已经查看了kendo网格的演示,但我不希望编辑所选产品的详细信息,而且我也不想使用单独的列详细信息按钮,如示例和演示中所示

我也查看过kendo ui的音乐商店演示,但是我无法理解它的代码作为jQuery中的代码而且我正在使用带有razor语法的asp.net mvc来实现我的项目

注意: 我希望窗口只在我点击产品名称并显示其详细信息时才会出现。

2 个答案:

答案 0 :(得分:0)

您可以使用:

$('#grid').on("click", "tr.k-state-selected", function (e) {
    // open window here
    // you have i.e. Id here $('#grid').dataItem($('#grid').select()).Id
});

为此,您必须在网格配置中设置选项selectable: "row"。 否则你只能使用:

$('#grid').on("click", "tr", function (e) { ... }

答案 1 :(得分:0)

您可以使用detailTemplate来实现它。

 <script>
            var wnd,
                detailsTemplate;

            $(document).ready(function () {
                var grid = $("#grid").kendoGrid({
                    dataSource: {
                       pageSize: 20,
                       data: createRandomData(50)
                    },
                    pageable: true,
                    height: 550,
                    columns: [
                        { field: "FirstName", title: "First Name", width: "140px" },
                        { field: "LastName", title: "Last Name", width: "140px" },
                        { field: "Title" },
                        { command: { text: "View Details", click: showDetails }, title: " ", width: "180px" }]
                }).data("kendoGrid");

                wnd = $("#details")
                    .kendoWindow({
                        title: "Customer Details",
                        modal: true,
                        visible: false,
                        resizable: false,
                        width: 300
                    }).data("kendoWindow");

                detailsTemplate = kendo.template($("#template").html());
            });

            function showDetails(e) {
                e.preventDefault();

                var dataItem = this.dataItem($(e.currentTarget).closest("tr"));
                wnd.content(detailsTemplate(dataItem));
                wnd.center().open();
            }
        </script>

        <script type="text/x-kendo-template" id="template">
            <div id="details-container">
                <h2>#= FirstName # #= LastName #</h2>
                <em>#= Title #</em>
                <dl>
                    <dt>City: #= City #</dt>
                    <dt>Birth Date: #= kendo.toString(BirthDate, "MM/dd/yyyy") #</dt>
                </dl>
            </div>
        </script>

转到此fiddle进行演示

[<强>更新] 这是用于在点击产品名称时显示窗口的代码段

 <script>
            var wnd,
                detailsTemplate;

            $(document).ready(function () {
                var grid = $("#grid").kendoGrid({
                    dataSource: {
                       pageSize: 20,
                       data: createRandomData(50)
                    },
                    pageable: true,
                    height: 550,
                    columns: [
                        { field: "FirstName", title: "First Name", width: "140px",attributes: { "class": "FirstName"} },
                        { field: "LastName", title: "Last Name", width: "140px" },
                        { field: "Title" }]
                }).data("kendoGrid");

                wnd = $("#details")
                    .kendoWindow({
                        title: "Customer Details",
                        modal: true,
                        visible: false,
                        resizable: false,
                        width: 300
                    }).data("kendoWindow");

                detailsTemplate = kendo.template($("#template").html());

                $('#grid').on("click", ".FirstName", function (e) {

                  e.preventDefault();

                var dataItem =               $("#grid").getKendoGrid().dataItem($(e.currentTarget).closest("tr"));
                wnd.content(detailsTemplate(dataItem));
                wnd.center().open();


  });
            });


        </script>

        <script type="text/x-kendo-template" id="template">
            <div id="details-container">
                <h2>#= FirstName # #= LastName #</h2>
                <em>#= Title #</em>
                <dl>
                    <dt>City: #= City #</dt>
                    <dt>Birth Date: #= kendo.toString(BirthDate, "MM/dd/yyyy") #</dt>
                </dl>
            </div>
        </script>

Working demo is here