AngularJS監(jiān)聽ng-repeat渲染完成的方法
某個項目,我的網(wǎng)頁中有一個列表<ul>元素,樣式如下:

實際上它是通過Angular的ng-repeat形成的,html中的代碼是:
<li ng-repeat="for list in lists()" id="{{ list.id }}">{{ list.name }}</li>
圖中下方的新建清單button,點擊之后就往lists數(shù)組中push了一個新的list對象,此時頁面會自動渲染,也對應增加一個<li>,如下:

注意MyList1一直是active狀態(tài)的(class="active"),我的需求是新增list后,把新增的list設(shè)置為active,即在新增后就變成下面這種樣式:

剛開始我嘗試在button對應的函數(shù)中,往lists數(shù)組中push了新的list對象后,使用document.getElementById獲取到新增的<li>對象,然后為其添加一個class="active",結(jié)果發(fā)現(xiàn)獲取到的DOM對象為null,經(jīng)過搜索發(fā)現(xiàn)原因是:往lists數(shù)組push對象后,數(shù)組發(fā)生改變,所有的<li>都會重新渲染,在push完成之后馬上去找新增的DOM對象,DOM還沒渲染好,因此是獲取不到的。解法是:使用AngularJS的指令去監(jiān)聽ng-repeat是否渲染完成,在渲染完成后,再去取新增的<li>對象,這個網(wǎng)上有很多相關(guān)的內(nèi)容了,代碼如下:
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表示已經(jīng)渲染到了最后一個對象,此時執(zhí)行change_list函數(shù)(定義在控制器中,功能是把當前active的對象取消active,然后設(shè)置傳入的DOM對象為active),element[0]可以直接取到當前渲染的DOM元素。注意我使用了$timeout,10ms后執(zhí)行change_list,我發(fā)現(xiàn)直接使用change_list還是會找不到DOM,原因不明,期待大神解答。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Angular實現(xiàn)的table表格排序功能完整示例
這篇文章主要介紹了Angular實現(xiàn)的table表格排序功能,結(jié)合完整實例形式分析了AngularJS表格排序所涉及的事件響應、元素遍歷、屬性修改等相關(guān)操作技巧,需要的朋友可以參考下2017-12-12
詳解Angular路由 ng-route和ui-router的區(qū)別
這篇文章主要介紹了詳解Angular路由 ng-route和ui-router的區(qū)別,分別介紹了兩種路由的用法和區(qū)別,有興趣的可以了解一下2017-05-05
Angular 4.x 動態(tài)創(chuàng)建表單實例
本篇文章主要介紹了Angular 4.x 動態(tài)創(chuàng)建表單實例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04
詳解基于Angular4+ server render(服務(wù)端渲染)開發(fā)教程
本篇文章主要介紹了詳解基于Angular4+ server render(服務(wù)端渲染)開發(fā)教程 ,具有一定的參考價值,有興趣的可以了解一下2017-08-08

