加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

angularjs – 在ng-repeat内找不到md-sidenav句柄的实例

发布时间:2020-12-17 17:41:11 所属栏目:安全 来源:网络整理
导读:我正在尝试创建一个由多个动态创建的md-sidenavs组成的堆栈.我可以将他们的ID推送到堆栈,但是在使用ng-repeat时无法切换它们. 使用: app.controller('MenuCtrl',['$scope','$mdSidenav',function($scope,$mdSidenav) { var stack = []; $scope.getStack = f
我正在尝试创建一个由多个动态创建的md-sidenavs组成的堆栈.我可以将他们的ID推送到堆栈,但是在使用ng-repeat时无法切换它们.

使用:

app.controller('MenuCtrl',['$scope','$mdSidenav',function($scope,$mdSidenav) {
  var stack = [];

  $scope.getStack = function() {
    return stack;
  }

  $scope.add = function(id) {
    stack.push(id);
  }

  $scope.toggle = function(id) {
    $mdSidenav(id).toggle();
  }
}]);

有:

<md-button ng-click="add('test')" class="menuBtn">Add</md-button>
<md-button ng-click="toggle('test')" class="menuBtn">Toggle</md-button>
<md-sidenav class="md-sidenav-left md-whiteframe-z2" md-component-id="{{id}}" ng-repeat="id in getStack()">
  {{id}}
</md-sidenav>

单击“添加”按钮可按预期在doc中生成md-sidenav元素.但是,Toggle按钮除了在控制台中产生“找不到句柄测试的实例”错误之外什么都不做.使用md-component-id =“test”声明静态md-sidenav工作正常.我正在使用AngularJS 1.3.15和Angular Material 0.8.3.

解决方法

从`Sidenav’指令 source,它似乎不接受md-component-id的动态值

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读