Kendo Grid:在Angular中获取小部件实例

时间:2015-02-11 06:04:06

标签: jquery angularjs kendo-ui telerik kendo-grid

我试图在我的Angular Controller中获取一个Kendo网格的实例,所以我可以尝试连接一些事件(和调用方法)我知道这可能不是最佳实践(并且应该使用自定义指令),但根据documentation,我们应该可以使用......

<div ng-app="app" ng-controller="MyCtrl">
<input kendo-datepicker="datePicker" k-on-change="onChange()">
</div>
<script>
 angular.module("app", [ "kendo.directives" ]).controller("MyCtrl",
   function($scope) {
 $scope.onChange = function() {
 alert($scope.datePicker.value());
};

});

所以,我试图对网格做同样的事情。我有以下标记...

<div ng-controller="Grid">
  <div kendo-grid='grid' k-options="vm.gridOptions"></div>  
</div>

然后在控制器js文件中..

  angular
    .module("mygrid")
    .controller("Grid", ['$scope', Grid]);

    function Grid($scope) {             
      var gridInstance = $scope.grid;
      ...

可以看到here

但是,gridInstance始终未定义。有谁知道我是否应该能够用网格做到这一点,如果是这样,为什么以上总是返回undefined?

提前感谢您提供任何帮助

彼得

1 个答案:

答案 0 :(得分:5)

两个问题:

  1. 如果您使用&#34;控制器作为&#34;语法,您需要为要访问的内容添加前缀(在您的情况下,您需要kendo-grid="vm.grid"而不是kendo-grid="grid"
  2. 当您的控制器被实例化时,Kendo UI小部件尚未存在(类似问题here),因此您需要使用全局Kendo UI事件等待它
  3. 所以你的Html变成了:

    <div data-ng-app="app">
        <div data-ng-controller="Grid as vm">
            <div kendo-grid="vm.grid" k-options="vm.options"></div>
            <div>{{vm.msg}}</div>
        </div>
    </div>
    

    您的应用:

    (function () {
        angular.module("app", ["kendo.directives"])
            .controller("Grid", ["$scope", Grid]);
    
        function Grid($scope) {
            var vm = this;
    
            var gridData = [{
                col1: 'data1',
                col2: 'data2'
            }, {
                col1: 'data1',
                col2: 'data2'
            }];
    
            vm.options = {
                dataSource: gridData,
                editable: true
            };
    
            $scope.$on("kendoRendered", function (event) {
                var gridInstance = vm.grid;
                console.log(vm);
                vm.msg = gridInstance === undefined ? "undefined" : "defined";
            });
        }
    })();
    

    updated demo