angularjs的ng-repeat回调

Posted Sylvia小伊

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了angularjs的ng-repeat回调相关的知识,希望对你有一定的参考价值。

  首先html代码是这样的:

<label>Name des Leiters:</label>
<select name="leaderID" id="selectLeaderID">   <option ng-repeat="manager in managers" value="leader_id={{manager.id}}&leader_name={{manager.name}}&leader_email={{manager.email}}" callback-on-end>{{manager.name}}</option> </select>

  因为只有一个ID确定,需要设置option的selected值,但是又不能直接用ng-model或者$().val()来设置,因为value是一长串东西= =0。0我为什么要写这样的代码

所以,只能通过ng-repeat的加载完成后调用回调函数,来完成设置。

  代码如下:

  app.directive("callbackOnEnd", function($timeout) {
      return {
          restrict: "A",
          link: function(scope, element, attrs) {
              if (scope.$last) {
                $timeout(function(){
                  var select = document.getElementById("selectLeaderID");
                  for(var i = 0;i < select.options.length;i++){
                        var parts = [];
                        parts = select.options[i].value.split(‘&‘);
                        if(parts[0].substr(10) == scope.selectLeaderID){
                            select.options[i].selected = true;
                        }
                    }
                });
              }
          }
      };
  });

  添加一个directive,注意要用到$timeout否则每次设置option时都会加载一次,而不是最后加载。

  最后祝各位小朋友们好好学习,天天向上,哈哈哈哈下周复活节放假可以来个西班牙葡萄牙游!


以上是关于angularjs的ng-repeat回调的主要内容,如果未能解决你的问题,请参考以下文章

angularjs中常见错误

ng-repeat 内的 ng-repeat 和每个项目的 td - AngularJS

AngularJS数组到ng-repeat

AngularJS的ng-repeat显示表格

嵌套 ng-repeat 的 AngularJS 记录计数

ng-repeat中的Angularjs分页