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

首頁 > 編程 > JavaScript > 正文

Angular 根據 service 的狀態更新 directive

2019-11-20 10:17:56
字體:
來源:轉載
供稿:網友

Angular JS (Angular.JS) 是一組用來開發Web頁面的框架、模板以及數據綁定和豐富UI組件。它支持整個開發進程,提供web應用的架構,無需進行手工DOM操作。

AngularJS是為了克服HTML在構建應用上的不足而設計的。HTML是一門很好的為靜態文本展示設計的聲明式語言,但要構建WEB應用的話它就顯得乏力了。這里AngularJS就應運而生,彌補了HTML的天然缺陷,用于構件Web應用等。

TL;DR

這篇文章講解了三種根據 service 的狀態更新 directive 的做法。分別是 $watch 表達式,事件傳遞,和 controller 的計算屬性。

問題

我有一個 readerService ,其中包含一些狀態信息(比如連接狀態和電量)。現在我需要做一個 directive 去展示這些狀態。因為它只需要從 readerService 中獲取數據,不需要任何外部傳值,所以我直接把 service 注入進去。但如何更新就成了一個問題。

service 的代碼如下。

const STATUS = {DETACH: 'DETACH',ATTACH: 'ATTACH',READY: 'READY'}class ReaderService {constructor() {this.STATUS = STATUS// The status will be changed by some callbacksthis.status = STATUS.DETACH}}angular.module('app').service('readerService', readerService)

directive 代碼如下:

angular.module('app').directive('readerIndicator', (readerService) => {const STATUS = readerService.STATUSconst STATUS_DISPLAY = {[STATUS.DETACH]: 'Disconnected',[STATUS.ATTACH]: 'Connecting...',[STATUS.READY]: 'Connected',}return {restrict: 'E',scope: {},template: `<div class="status">{{statusDisplay}}</div>`,link(scope) {// Set and change scope.statusDisplay here}}})

我嘗試過以下幾種辦法,下面一一介紹。

方法一:$watch

第一個想到的方法就是在 directive 中用 $watch 去監視 readerService.status 。因為它不是 directive scope 的屬性,所以我們需要用一個函數來包裹它。Angular 會在 dirty-checking 時計算和比較新舊值,只有狀態真的發生了改變才會觸發回調。

// In directivelink(scope) {scope.$watch(() => readerService.status, (status) => {scope.statusDisplay = STATUS_DISPLAY[status]})}

這個做法足夠簡單高效,只要涉及 readerService.status 改變的代碼會觸發 dirty-checking ,directive 就會自動更新。service 不需要修改任何代碼。

但如果有多個 directive 的屬性都受 service status 的影響,那 $watch 代碼就看得比較晦澀了。尤其是 $watch 修改的值會影響其他的值的時候。比如:

// In directivelink(scope) {scope.$watch(() => readerService.status, (status) => {scope.statusDisplay = STATUS_DISPLAY[status]scope.showBattery = status !== STATUS.DETACH})scope.$watch('showBattery', () => {// some other things depend on showBattery})}

這種時候聲明式的編程風格會更容易看懂,比如 Ember 或 Vue 里面的 computed property 。這個待會討論。

方法二:$broadcast/$emit + $on

這種思路是 service 每次狀態改變都發送一個事件,然后 directive 監聽事件來改變狀態。因為 directive 渲染的時候也許 status 已經更新了。所以我們需要在 link 中計算一個初始值。

我最開始是用 $broadcast 去做的。代碼如下:

// In servicesetStatus(value) {this.status = value// Need to inject $rootScopethis.$rootScope.$broadcast('reader.statusChanged', this.status)}// In directivelink(scope) {scope.statusDisplay = STATUS_DISPLAY[nfcReaderService.status]scope.$on('reader.statusChanged', (event, status) => {scope.statusDisplay = STATUS_DISPLAY[status]})}

但馬上發現 $broadcast 之后 UI 更新總要等 1 秒多(不過 $on 回調倒是很快)。Google 一番后知道原因是 $broadcast 是向下層所有 scope 廣播,廣播完成后再 dirty-checking 。一個更好的做法是使用 $emit ,它只會向上傳遞事件,不過不管發送事件還是監聽事件都得用 $rootScope 。

修改后的代碼如下:

// In servicesetStatus(value) {this.status = value// Use $emit instead of $broadcastthis.$rootScope.$emit('reader.statusChanged', this.status)}// In directivelink(scope) {scope.statusDisplay = STATUS_DISPLAY[nfcReaderService.status]// Use $rootScope instead of scope$rootScope.$on('reader.statusChanged', (event, status) => {scope.statusDisplay = STATUS_DISPLAY[status]})}

如果因為某些原因不得不用 $broadcast 的話,你可以在 $on 回調最后用 $digest 或 $apply 強制觸發 dirty-checking ,這也可以達到快速更新 UI 的目的。

方法三:controller + property

我個人覺得前兩個方法能解決問題,但代碼維護性都不太好。 $watch 在屬性相互關聯的情況下非常難看懂, $emit/$on 需要把一些邏輯寫兩次(初始化 directive 時和回調執行時)。方法一中我提到了有些時候聲明式的屬性比 $watch 更容易看懂。這個方法就是使用 controller 。directive 可以設置自己的 controller 作為數據來源(或者說 view model),我們可以把那些需要計算的屬性作為 controller 的屬性。這樣 dirty-checking 時它們就會自動計算。

// In directiveclass ReaderController {constructor($scope, readerService) {this.readerService = readerService}get statusDisplay() {return STATUS_DISPLAY[this.readerService.status]}}return {// ...controller: ReaderController,controllerAs: 'vm',template: `<div class="status">{{vm.statusDisplay}}</div>}

這樣一來,大部分邏輯都可以挪到 controller 中。如果沒有 DOM 操作我們甚至可以不寫 link 方法。也沒必要加入額外的 $watch 和 $on 。只是因為 dirty-checking 的特性,綁定到 template 的屬性往往會多計算幾次。所以屬性必須非常簡單。大部分情況下這不會有什么問題。

以上內容是小編給大家介紹的Angular 根據 service 的狀態更新 directive,希望對大家有所幫助!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
96sao精品视频在线观看| 91高清在线免费观看| 久久香蕉精品香蕉| 国产精品大陆在线观看| 亚洲成人在线网| 成人免费在线视频网址| 欧美性猛交xxxx黑人猛交| 亚洲男子天堂网| 色樱桃影院亚洲精品影院| 国产在线视频2019最新视频| 国产成人精品在线视频| 精品美女久久久久久免费| 久久精品国产亚洲精品| 亚洲色图18p| 成人性生交大片免费看视频直播| 亚洲精品国产精品自产a区红杏吧| 最近2019年中文视频免费在线观看| 久久国产精品久久精品| 欧美日韩国产成人高清视频| 久热精品在线视频| 日韩电影大片中文字幕| 亚洲色图35p| 精品久久久久久中文字幕| 久久影视免费观看| 在线观看久久av| 久久久久久亚洲精品中文字幕| 国产精品成人观看视频国产奇米| 欧美丰满少妇xxxxx做受| 亚洲精品videossex少妇| 色777狠狠综合秋免鲁丝| 日韩在线欧美在线国产在线| 亚洲最大激情中文字幕| 91在线免费看网站| 日韩中文字幕视频| 亚洲美女喷白浆| 亚洲成人久久久久| 欧美美最猛性xxxxxx| 亚洲国产精彩中文乱码av在线播放| 热久久99这里有精品| 欧美激情精品久久久久久免费印度| 欧美网站在线观看| 日韩精品中文字幕久久臀| 亚洲精品国产欧美| 国产精品第七十二页| 黄色成人av网| 亚洲热线99精品视频| 国产成人一区二区三区小说| 精品一区精品二区| 欧美限制级电影在线观看| 爽爽爽爽爽爽爽成人免费观看| 亚洲欧美日韩网| 96精品久久久久中文字幕| 中文日韩在线观看| 色午夜这里只有精品| 欧美国产日本在线| 在线电影欧美日韩一区二区私密| 久久av.com| 热久久这里只有精品| 成人国产精品av| 久久国产精品久久久| 日韩精品视频在线| 国产精品视频最多的网站| 成人午夜在线影院| 成人亚洲综合色就1024| 中文字幕av一区| 亚洲成人av在线| 神马久久久久久| 国产伦精品免费视频| 久久久久久国产免费| 伊人av综合网| 欧美国产日韩免费| 精品高清美女精品国产区| 91在线免费网站| 久久久欧美精品| 在线精品视频视频中文字幕| 国产一区二区三区在线免费观看| 国产精品视频中文字幕91| 97在线精品视频| 成人午夜小视频| 国产精品高潮呻吟视频| 中文字幕精品久久久久| 国产精品极品美女在线观看免费| 日韩不卡在线观看| 久久这里只有精品99| 亚洲精品在线不卡| 日韩专区在线播放| 色播久久人人爽人人爽人人片视av| 久久激情五月丁香伊人| 日韩成人在线播放| 亚洲最大激情中文字幕| 亚洲久久久久久久久久| 欧美高清不卡在线| 国产精品久久中文| 成人午夜一级二级三级| 国产日韩欧美在线播放| 久久久久久综合网天天| 夜夜狂射影院欧美极品| 欧美丰满老妇厨房牲生活| 成人精品网站在线观看| 97热精品视频官网| 亚洲成年人影院在线| 亚洲美女精品久久| 亚洲精品美女久久久久| 国产狼人综合免费视频| 98精品国产高清在线xxxx天堂| 69国产精品成人在线播放| 欧美成人精品影院| 91精品国产综合久久久久久蜜臀| 欧美专区日韩视频| 高清欧美性猛交xxxx黑人猛交| 亚洲国产一区二区三区四区| 精品久久久久久久久久ntr影视| 国模视频一区二区三区| 在线观看久久久久久| 精品亚洲国产视频| 福利视频一区二区| 国产精品久久久久免费a∨| 狠狠躁18三区二区一区| 国产精品久久久久久久久久久久久| 欧亚精品中文字幕| 日韩免费av片在线观看| 亚洲国产中文字幕在线观看| 亚洲一二在线观看| 97视频com| 91久久嫩草影院一区二区| 国产999在线| 亚洲国产日韩欧美综合久久| 欧美夜福利tv在线| 精品女厕一区二区三区| 久久综合国产精品台湾中文娱乐网| 国产成人在线亚洲欧美| 91日韩在线视频| 国产精品视频中文字幕91| 精品女同一区二区三区在线播放| 亚洲激情第一页| 中日韩美女免费视频网站在线观看| 伊人久久大香线蕉av一区二区| 国产美女精彩久久| 亚洲成人久久久| 亚洲国产精品成人av| 97视频com| 亚洲国产精品va在线观看黑人| 国产精品视频男人的天堂| 国产www精品| 欧美日本高清视频| 羞羞色国产精品| 精品国产一区二区三区久久狼5月| 欧美成人免费全部观看天天性色| 成人福利网站在线观看11| 亚洲欧美在线x视频| 伊人成人开心激情综合网| 91av视频在线免费观看| 国模私拍视频一区| 伊人一区二区三区久久精品| 日本不卡免费高清视频| 热99精品只有里视频精品| 日韩免费在线电影| 亚洲欧美在线看| 欧美大片免费观看在线观看网站推荐| 97在线观看视频| 中文字幕久精品免费视频| 成人网在线免费观看| 久久成人国产精品| 亚洲欧美日韩视频一区|