angularjs – Kendo UI和angular – $scope中没有小部件

前端之家收集整理的这篇文章主要介绍了angularjs – Kendo UI和angular – $scope中没有小部件前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用AngularJS版本1.2.27的Kendo UI版本2014.2.716,我使用指令制作了一个网格

<div ng-controller="MyController as ctrl">
    <div id="myGrid" kendo-grid k-options="{some options}"></div>
    <button ng-click="ctrl.doSomething()"></div>
</div>

我读到如果你给网格命名(如:kendo-grid =“myGridOnScope”),你可以这样访问控制器范围中的小部件:

myModule.controller('MyController',function($scope) {
   this.doSomething = function() {
       console.log($scope.myGridOnScope);
   }
}

console.log应该记录一个widget对象,但在我的情况下它是未定义的.我究竟做错了什么?谢谢您的帮助

解决方法

我自己发现了问题,所以如果有人遇到同样的问题,我会发一个答案.如果您在AngularJS中使用controllerAs语法,则不能只写入窗口小部件的名称 – 您必须在其前面加上控制器别名.

看看这个例子:

<div ng-controller="MyController as ctrl">
    <div kendo-grid="myGridName"></div>
</div>

这不会给你$scope上的网格对象 – 因为你需要添加ctrl前缀:

<div ng-controller="MyController as ctrl">
    <div kendo-grid="ctrl.myGridName"></div>
</div>

现在您可以访问控制器中的小部件,如下所示:

angular.module('MyModule',['kendo.directives'])
    .controller('MyController',function($scope){
        // this gives you the widget object
        console.log(this.myGridName);

        // however,this doesn't work
        console.log($scope.myGridName);
});

我希望通过这篇文章帮助过某人.干杯,

猜你在找的Angularjs相关文章