亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

AngularJS 多指令Scope問題的解決

2019-11-19 12:38:14
字體:
來源:轉載
供稿:網友

問題描述

不確定度指令,傳入參量類別,然后該指令列出該類別下的所有不確定度。

新增頁面用到了三個該指令,只有最后一個成功,前兩個都沒有數據。

探究源碼

以下是指令源碼:

'use strict';/** * @ngdoc directive * @name webappApp.directive:yunzhiAccuracyUncertainty * @description * # yunzhiAccuracyUncertainty * 不確定度指令 * zhangxishuo */angular.module('webappApp') .directive('yunzhiAccuracyUncertainty', function($filter) {  return {   templateUrl: 'views/directive/yunzhiAccuracyUncertainty.html',   restrict: 'E',   scope: {    parameterCategory: '=',   // 參量類別    ngModel: '='     // 不確定度   },   link: function postLink(scope, element, attrs) {    var self = this;    // 初始化    self.init = function() {     // 初始化不確定度空列表     scope.accuracyList = [];     // 監聽參量類別     scope.$watch('parameterCategory', self.watchParameterCategory);     // 監聽不確定度     scope.$watch('ngModel', self.watchNgModel);    };    // 監聽參量類別    self.watchParameterCategory = function(newValue) {     if (newValue && newValue.id) {      // 設置不確定度列表      scope.accuracyList = newValue.accuracyUncertaintyList;      // 過濾數據      self.filter();     }    };    // 監聽不確定度    self.watchNgModel = function(newValue) {     if (newValue && newValue.id) {      // 設置默認選中      scope.selected = newValue;     }    };    // 過濾數據    self.filter = function() {     angular.forEach(scope.accuracyList, function(accuracy) {      // 過濾不確定度      accuracy._value = $filter('yunzhiAccuracyWithUnit')(accuracy);     });    };    // 更新模型    self.updateModel = function(selected) {     // 更新數據     scope.ngModel = selected;    };    // 傳給視圖    scope.updateModel = self.updateModel;    self.init();   }  }; });

嘗試

嘗試打印了一下scope.accuracyList,果然有問題。

前兩個都是空,最后一個數組有值。

想不明白,這里明明監聽參量類別,并將scopeaccuracyList設置了值???為什么沒有呢?

scope

嘗試打印一下scope。

去關注scope$id就行了。

依次打印的是:

504508   // 第一個指令506508   // 第二個指令508508   // 第三個指令

前兩個指令執行時賦值的是一個scope,而過濾的又是另一個scope,所以過濾不出數據,最后一個是同一scope,所以正常輸出。

原因

官方文檔

HTML Compiler - AngularJS

HTML Compiler允許開發者教會瀏覽器一些新的語法,AngularJS稱這個為指令。

Compiler是一個遍歷DOM去搜尋屬性的AngularJS服務,編譯分為以下兩個階段。

  • Compile:遍歷DOM并收集所有的指令,返回結果是一個linking函數。
  • Link:使用scope整合指令并產生動態視圖,任何scope模型上的改變都會反映到視圖上,任何視圖上的用戶交互也會反映到scope模型上。

指令如何編譯

AngularJS操作DOM節點而不是字符串,這很重要。但通常,你不需要關注這個,因為當頁面加載時,瀏覽器會自動把HTML轉換為DOM。

指令編譯有以下三階段:

  • $compile遍歷DOM并匹配指令,如果compiler發現有匹配指令的元素,就會將該指令添加到指令列表中。一個元素可能匹配多個指令。
  • 一旦所有匹配DOM元素的指令都被確定,然后compiler會根據優先級對指令進行排序。每一個指令的compile函數都會被執行,每一個compile函數都有操作DOM的機會。compile會返回link函數,這些函數被組合成一個“組合的”link函數,它能調用每個指令返回的link函數。
  • $compile會調用上一步中的“組合的”link函數來鏈接scope和模板。

下面是官方的示意代碼:

// HTML字符串var html = '<div ng-bind="exp"></div>';// 將HTML字符串轉換為DOM模板var template = angular.element(html);// 編譯DOM模板返回link函數var linkFn = $compile(template);// 將編譯后的模板與scope鏈接var element = linkFn(scope);// 添加到DOM中parent.appendChild(element);

分析

compile只在編譯時執行一次,只要頁面中存在一個該指令,該指令的link方法就執行一次。

所以,AngularJS使用$compile編譯我的指令,然后看我頁面中用到了三個該指令,并且都是獨立scope,所以就創建了三個scope。

然后使用這三個scope去調用link函數。

前面已經提到,AngularJS會將link函數統一組合成一個“組合的”link函數,所以我們可以猜想,組合函數中的link函數的數量與指令的數量一致,所以三次調用的是一個link函數,link函數只有一個實例!

linkFn(scope)

scope傳進去作為link函數的入參。

上面的事件監聽都是沒毛病的,將傳入的scope綁定到視圖,然后添加到DOM中,然后就與這個link函數無關了。

但是這個filter就不行了。

第一個scope調用,filter功能是過濾第一個scopeaccuracyList,第二個scope調用,filter功能是過濾第二個scopeaccuracyList。

所以第三次執行時,第三個scope將之前的兩個都覆蓋了,link函數中的filter的作用變成了過濾最后一個scopeaccuracyList

<!-- 不確定度 --><ui-select ng-model="selected" theme="bootstrap" ng-change="updateModel(selected)"> <ui-select-match placeholder="請選擇">  {{ $select.selected._value }} </ui-select-match> <ui-select-choices repeat="accuracy in accuracyList">  <div ng-bind-html="accuracy._value"></div> </ui-select-choices></ui-select>

所以這里下拉框顯示的是不確定度過濾后的_value的值,這里的空字符串看起來不明顯,加上test測試一下。

所以,這塊視圖綁定的scope是正確的,只是時間監聽之后去過濾數據,因為過濾的并不是當前scope的數據,所以accuracy._value就沒有值,是undefined,所以顯示一個空的字符串。

解決方案

明白了原理之后解決問題自然易如反掌,只需將filterscope獨立即可,這樣就不受每次執行不同scope的影響了。

總結

很多東西,書上是沒有的,需要我們自己去發現,去分析,去解決。

翻開了之前遇到指令編譯問題時從別人博客里學習來的手動編譯方法。

angular.module('webappApp') .directive('reCompile', function($compile) {  return {   restrict: 'A',   link: function postLink(scope, element, attrs) {    // 監聽使用該指令的元素上的ngBindHtml    attrs.$observe('ngBindHtml', function() {     // 如果元素使用了ngBindHtml指令     if (attrs.ngBindHtml) {      // 重新編譯      $compile(element[0].children)(scope);     }    });   }  }; });

記得之前的需求是,數據經過過濾器過濾,返回的是一段HTML代碼,雖然使用ng-bind-html能將該段代碼添加到DOM中,但是這段代碼中有指令,因為該指令不是初始時就有的,所以,這個指令是不會被編譯的。

所以需要編寫一個重新編譯的指令,手動編譯動態創建的指令。

記得當時,看這段代碼也不是那么完全理解,現在學習完指令的編譯之后,再去翻看之前的代碼,一切原來是如此簡單。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美激情另类校园| 久久久久国产视频| 国产精品亚洲аv天堂网| 久久九九有精品国产23| 亚洲一区中文字幕在线观看| 久久九九有精品国产23| 懂色av一区二区三区| 精品久久香蕉国产线看观看gif| 免费成人高清视频| 欧美日韩国产影院| 麻豆乱码国产一区二区三区| 国产精品午夜一区二区欲梦| 欧美午夜影院在线视频| 亚洲在线观看视频| 国产一区二区日韩精品欧美精品| 成人久久一区二区三区| 国产精品国产自产拍高清av水多| 久久精品国产亚洲| 国外日韩电影在线观看| 亚洲直播在线一区| 精品性高朝久久久久久久| 中文一区二区视频| 欧美成人三级视频网站| 精品高清一区二区三区| 日韩中文综合网| 一区二区三区美女xx视频| 欧美激情亚洲精品| 日韩在线观看免费高清| 亚洲男人第一网站| 91精品综合久久久久久五月天| 69av在线视频| 日韩精品高清在线观看| 成人网页在线免费观看| 欧美亚洲国产视频| 日韩欧美一区二区三区久久| 91亚洲国产成人精品性色| 成人www视频在线观看| 欧美福利小视频| 国产精品视频色| 亚洲乱码国产乱码精品精| 国产亚洲精品久久久久久777| 欧美性色xo影院| 亚洲最大的成人网| 中文字幕亚洲欧美在线| 久久久99久久精品女同性| 久久免费视频网| 日韩中文字幕网址| 在线观看亚洲视频| 富二代精品短视频| 久久久国产成人精品| 精品国产欧美一区二区五十路| 中文字幕亚洲无线码在线一区| 中文字幕在线国产精品| 另类天堂视频在线观看| 亚洲码在线观看| 69久久夜色精品国产69乱青草| 久久99国产精品久久久久久久久| 亚洲免费电影一区| 国产成人精品在线视频| 亚洲黄色有码视频| 国产在线98福利播放视频| 亚洲天堂一区二区三区| 国产97色在线| 色偷偷噜噜噜亚洲男人的天堂| 日韩最新av在线| 成人av资源在线播放| 欧美色播在线播放| 精品国产91久久久久久| 亚洲性线免费观看视频成熟| 日韩亚洲欧美中文高清在线| 精品少妇v888av| 日韩电视剧在线观看免费网站| 成人h片在线播放免费网站| 亚洲国产日韩精品在线| 亚洲社区在线观看| 欧美性极品xxxx做受| 亚洲精品成人久久| 亚洲另类欧美自拍| 欧洲美女免费图片一区| 91精品国产91久久久久久最新| 久久久亚洲精品视频| 久久91超碰青草是什么| 欧美激情综合色综合啪啪五月| 亚洲剧情一区二区| yw.139尤物在线精品视频| 欧美精品在线免费播放| 国模极品一区二区三区| 国产91av在线| 91精品久久久久久久久中文字幕| 亚洲久久久久久久久久久| 亚洲自拍小视频| 亚洲欧美国产制服动漫| 亚洲少妇激情视频| 亚洲大胆美女视频| 最近2019中文字幕大全第二页| 国产精品成人一区二区三区吃奶| 精品国产一区二区三区久久久| 欧美成人免费va影院高清| 久久不射电影网| 97久久精品人搡人人玩| 亚洲精品久久久久中文字幕二区| 亚洲韩国青草视频| 国产精品盗摄久久久| 77777亚洲午夜久久多人| 国产精品久久久久久久久免费看| 国产成人精品在线观看| 中文字幕一区日韩电影| 久久国产精彩视频| 97在线视频免费观看| 伊人精品在线观看| 国产成人jvid在线播放| 91在线观看免费高清完整版在线观看| 国产z一区二区三区| 日韩极品精品视频免费观看| 97在线免费视频| 亚洲色在线视频| 日韩一区二区三区在线播放| 欧美多人乱p欧美4p久久| 国产一区二区三区视频| 欧美激情欧美狂野欧美精品| 深夜精品寂寞黄网站在线观看| 欧美日韩国产精品一区二区三区四区| 中文字幕欧美亚洲| 日韩在线视频观看正片免费网站| 精品日本高清在线播放| 国产精自产拍久久久久久| 国产欧美精品在线播放| 91在线网站视频| 日韩av影片在线观看| www.欧美精品| 欧美激情成人在线视频| 8x海外华人永久免费日韩内陆视频| 欧美孕妇毛茸茸xxxx| 国产精品wwwwww| 在线a欧美视频| 国产在线观看91精品一区| 亚洲视频专区在线| 日韩av网站导航| 精品视频在线播放色网色视频| 中文字幕最新精品| 成人羞羞国产免费| 日本精品一区二区三区在线| 青草青草久热精品视频在线网站| 色一区av在线| 精品国产拍在线观看| 一本大道久久加勒比香蕉| 色噜噜狠狠色综合网图区| 亚洲影院在线看| 国产精品偷伦视频免费观看国产| 亚洲国产欧美一区二区三区同亚洲| 欧美激情按摩在线| 国产精品爽爽爽爽爽爽在线观看| 国产精品视频永久免费播放| 秋霞成人午夜鲁丝一区二区三区| 国外日韩电影在线观看| 亚洲a级在线播放观看| 欧美日韩中文字幕综合视频| 日韩av电影手机在线| 久久精品视频在线| 亚洲免费一在线| 亚洲免费一在线| 欧美日韩第一视频| 日韩免费电影在线观看| 亚洲免费成人av电影|