以编程方式从剑道网格中选择一行

恰帕

我有一个网格,它的其中一列是带有复选框的模板:

.Name("grid")
.Columns(columns =>
{
    columns.Bound(c => c.Id).ClientTemplate("<input type=\"checkbox\" id=\"chk_#=Id#\" class=\"gridCK\" onclick=\"zzz(this)\"/>");

当我选中复选框时,我希望其行被选中(反之亦然)。我尝试了以下方法:

function zzz(e) {
    var id = e.id;
    var grid = $("#grid").data("kendoGrid");
    var data = grid.dataSource.data();
    var res = $.grep(data, function (d) {
        if (('chk_' + d.Id) == id) {
            return d.Id;
        }
    });
    var row = grid.table.find('tr[data-id="' + res[0].Id + '"]');
    if (e.checked) {
        row.addClass("k-state-selected");
    } else {
        row.removeClass("k-state-selected");
    }
}

但是什么也没发生,row变量不是网格的实际行。

我该如何实现?

奥纳拜

将函数处理程序定义为:

function zzz(e) {
    var row = $(e).closest("tr");
    row.addClass("k-state-selected");
}

实际观看:

$(document).ready(function () {
  var crudServiceBaseUrl = "http://demos.telerik.com/kendo-ui/service",
      dataSource = new kendo.data.DataSource({
        transport: {
          read:  {
            url: crudServiceBaseUrl + "/Products",
            dataType: "jsonp"
          },
          parameterMap: function(options, operation) {
            if (operation !== "read" && options.models) {
              return {models: kendo.stringify(options.models)};
            }
          }
        },
        pageSize: 5,
        schema: {
          model: {
            id: "ProductID",
            fields: {
              ProductID: { editable: false, nullable: true },
              ProductName: { validation: { required: true } },
              UnitPrice: { type: "number", validation: { required: true, min: 1} },
              Discontinued: { type: "boolean" },
              UnitsInStock: { type: "number", validation: { min: 0, required: true } }
            }
          }
        }
      });

  var grid = $("#grid").kendoGrid({
    dataSource: dataSource,
    navigatable: true,
    pageable: true,
    columns: [
      "ProductName",
      { field: "UnitPrice", title: "Unit Price", format: "{0:c}", width: 120 },
      { field: "UnitsInStock", title: "Units In Stock", width: 120 },
      { field: "Select", template: "<input type=\"checkbox\" id=\"chk_#=ProductID#\" class=\"gridCK\" onclick=\"zzz(this)\"/>" }
    ],
    editable: false,
    selectable: "multiple"
  }).data("kendoGrid");
});

function zzz(i) {
  var row = $(i).closest("tr");
  row.addClass("k-state-selected");
}
html {
  font-size: 10px; 
  font-family: Arial, Helvetica, sans-serif; 
}
<link rel="stylesheet" href="http://cdn.kendostatic.com/2014.3.1119/styles/kendo.common.min.css" />
<link rel="stylesheet" href="http://cdn.kendostatic.com/2014.3.1119/styles/kendo.default.min.css" />
<script src="http://cdn.kendostatic.com/2014.3.1119/js/jquery.min.js"></script>
<script src="http://cdn.kendostatic.com/2014.3.1119/js/kendo.all.min.js"></script>

<div id="grid"></div>

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

如何以编程方式在QTreeview中选择一行?

来自分类Dev

在剑道网格中自动选择一行

来自分类Dev

是否可以通过编程方式在AnyGantt图表中选择一行?

来自分类Dev

UI-GRID可扩展网格。以编程方式扩展一行

来自分类Dev

如何在这个简单的 angularjs 网格中选择第一行

来自分类Dev

在Delphi ListView中以编程方式选择一行后,使用移位箭头断开的多项选择

来自分类Dev

在一行SQL中选择行对

来自分类Dev

通过使用Kendo在子网格中选择一行来将记录添加到父网格

来自分类Dev

在html表格中选择一行

来自分类Dev

在UIPickerView中选择一行-Swift

来自分类Dev

在listView中选择一行

来自分类Dev

在 dgv 中选择一行

来自分类Dev

如何获得剑道网格行选择

来自分类Dev

在DetailExpand事件上选择剑道网格行

来自分类Dev

如何获得剑道网格行选择

来自分类Dev

自动滚动剑道树视图以编程方式选择一个节点

来自分类Dev

使用Selenium Webdriver在ext-js网格中选择一行不适用于IE

来自分类Dev

在 CSS 网格中选择行

来自分类Dev

从相似行MYSQL中选择一行

来自分类Dev

从ZF2的行集中选择一行

来自分类Dev

在一行中选择表 3 行

来自分类Dev

如何以编程方式添加一行NSBox?

来自分类Dev

在自动生成的网格上选择一行

来自分类Dev

如何从任何hstore值中选择一行?

来自分类Dev

MySQL:在每个聚合组中选择最后一行

来自分类Dev

防止在MySQL中选择同一行

来自分类Dev

从Laravel中的一行中选择单列?

来自分类Dev

从文本文件中选择一行

来自分类Dev

在Postgres中选择一行作为JSON