久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

angular.js - ng-repeat嵌套的directive link函數未執行

瀏覽:229日期:2024-09-25 15:34:07

問題描述

http://codepen.io/whb/pen/wzjWYv

初始化的時候,可以走到link函數中將原數據處理之后再做顯示angular.js - ng-repeat嵌套的directive  link函數未執行

當點擊刷新之后angular.js - ng-repeat嵌套的directive  link函數未執行

實在無法理解 當ng-repeat中數據刷新之后 嵌套的directive未執行link函數,跪求各位大神指導

代碼如下:

(function() { ’use strict’; var app = angular.module(’plunker’, []); app.controller(’MainCtrl’, function($scope) { $scope.list = [{ name: '張三', age: 23 }, { name: '李四', age: 63 }]; //刷新按鈕 $scope.load = function() { $scope.list = [{name: '張三1',age: 23 }, {name: '李四1',age: 63 }]; }; }); app.directive(’item’, function() { return { restrict: ’A’, template: '<p>姓名:</p> <p>{{ item.name }}</p> <p>昵稱:</p> <p>{{ item.nickName }}</p> <p>年齡:</p> <p>{{item.age}}</p>', scope: {item: '=', }, link: function(scope, element, attrs) {scope.item.nickName = scope.item.name + 'nick';console.log(scope.item); } } });})();

<p ng-app='plunker'> <p ng-controller='MainCtrl' style='text-align: center;'> <p > <p ng-repeat='item in list track by $index' class='items-warp'><p item='item' class='row'></p> </p> </p> <button ng-click='load()'>刷新 </button> </p></p>

問題解答

回答1:

我說一下我的觀點,但不一定正確。

原因應該是你在ng-repeat上的 track by 語法造成的.

官方文檔中說ngRepeat是根據$watchCollection檢測相應的viewModel是不是改變過,增加了track by 后相當于對這個檢測機制附加了新的條件,當你第二次點擊刷新的時候,ngRepeat根據track by的條件得到的判斷其實是不需要重新渲染Dom的,所以就不會再次compile你定義的指令,而link方法是在compile之后才會調用的,所以無法調用到link方法。

compile 和 link 的分析:傳送門

相關文章:
主站蜘蛛池模板: 国产精品视频网站 | 中文字幕亚洲一区二区三区 | 欧洲毛片 | 亚洲成人av在线 | 欧美日韩视频 | 欧美一区2区三区4区公司二百 | av一区二区三区四区 | 91在线免费视频 | 欧美精品一区二区视频 | 日韩精品网站在线观看 | 精品少妇一区二区三区 | 日韩欧美国产成人一区二区 | 亚洲精品国精品久久99热 | 精品www| 妞干网av | 亚洲91 | 久久精品一 | 成人av免费在线观看 | 欧美wwwsss9999 | 9999国产精品欧美久久久久久 | 日韩aⅴ一区二区三区 | 日韩成人一区 | 欧美日韩综合视频 | 成人午夜sm精品久久久久久久 | 免费国产wwwwwww网站 | 国产一区二区视频在线观看 | www亚洲成人 | 中文字幕亚洲综合 | 精品99久久久久久 | 久久99国产精一区二区三区 | 亚洲精品久久久久久久久久久 | 国产www| 久久精品国产99国产精品 | 中文字幕最新在线 | 欧美日一区| 狠狠操夜夜操天天操 | 韩国电影久久影院 | 小草av| yy6080久久伦理一区二区 | 欧美激情免费 | 99国产视频|