某个项目,我的网页中有一个列表<ul> 元素,样式如下:
实际上它是通过Angular 的ng-repeat 形成的,html 中的代码是:
<li ng-repeat="for list in lists()" id="{{ list.id }}">{{ list.name }}</li>
图中下方的新建清单button ,点击之后就往lists 数组中push 了一个新的list 对象,此时页面会自动渲染,也对应增加一个<li> ,如下:
注意MyList1 一直是active 状态的(class="active" ),我的需求是新增list 后,把新增的list 设置为active ,即在新增后就变成下面这种样式:
刚开始我尝试在button 对应的函数中,往lists 数组中push 了新的list 对象后,使用document.getElementById 获取到新增的<li> 对象,然后为其添加一个class="active" ,结果发现获取到的DOM 对象为null ,经过搜索发现原因是:往lists 数组push 对象后,数组发生改变,所有的<li> 都会重新渲染,在push 完成之后马上去找新增的DOM 对象,DOM 还没渲染好,因此是获取不到的。解法是:使用AngularJS 的指令去监听ng-repeat 是否渲染完成,在渲染完成后,再去取新增的<li> 对象,这个网上有很多相关的内容了,代码如下:
myapp.directive('repeatFinish',function ($timeout) {
return {
restrict: "C",link: function (scope,element,attr) {
if(scope.$last === true){
$timeout(function () {
scope.change_list(element[0]);
},10);
}
}
}
});
上述代码建立了一个名为repeatFinish 的指令,restrict: "C" 表示指令放在DOM 的class 中(驼峰形式,即class="repeat-finish" ),scope.$last === true 表示已经渲染到了最后一个对象,此时执行change_list 函数(定义在控制器中,功能是把当前active 的对象取消active ,然后设置传入的DOM 对象为active ),element[0] 可以直接取到当前渲染的DOM 元素。注意我使用了$timeout ,10ms 后执行change_list ,我发现直接使用change_list 还是会找不到DOM ,原因不明,期待大神解答。 (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|