中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

Angular 根據(jù) service 的狀態(tài)更新 directive
來源:易賢網(wǎng) 閱讀:1110 次 日期:2016-07-08 15:41:54
溫馨提示:易賢網(wǎng)小編為您整理了“Angular 根據(jù) service 的狀態(tài)更新 directive”,方便廣大網(wǎng)友查閱!

Angular JS (Angular.JS) 是一組用來開發(fā)Web頁面的框架、模板以及數(shù)據(jù)綁定和豐富UI組件。它支持整個(gè)開發(fā)進(jìn)程,提供web應(yīng)用的架構(gòu),無需進(jìn)行手工DOM操作。

AngularJS是為了克服HTML在構(gòu)建應(yīng)用上的不足而設(shè)計(jì)的。HTML是一門很好的為靜態(tài)文本展示設(shè)計(jì)的聲明式語言,但要構(gòu)建WEB應(yīng)用的話它就顯得乏力了。這里AngularJS就應(yīng)運(yùn)而生,彌補(bǔ)了HTML的天然缺陷,用于構(gòu)件Web應(yīng)用等。

TL;DR

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

問題

我有一個(gè) readerService ,其中包含一些狀態(tài)信息(比如連接狀態(tài)和電量)?,F(xiàn)在我需要做一個(gè) directive 去展示這些狀態(tài)。因?yàn)樗恍枰獜?readerService 中獲取數(shù)據(jù),不需要任何外部傳值,所以我直接把 service 注入進(jìn)去。但如何更新就成了一個(gè)問題。

service 的代碼如下:

const STATUS = {

DETACH: 'DETACH',

ATTACH: 'ATTACH',

READY: 'READY'

}

class ReaderService {

constructor() {

this.STATUS = STATUS

// The status will be changed by some callbacks

this.status = STATUS.DETACH

}

}

angular.module('app').service('readerService', readerService)

directive 代碼如下:

angular.module('app').directive('readerIndicator', (readerService) => {

const STATUS = readerService.STATUS

const 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

第一個(gè)想到的方法就是在 directive 中用 $watch 去監(jiān)視 readerService.status 。因?yàn)樗皇?directive scope 的屬性,所以我們需要用一個(gè)函數(shù)來包裹它。Angular 會(huì)在 dirty-checking 時(shí)計(jì)算和比較新舊值,只有狀態(tài)真的發(fā)生了改變才會(huì)觸發(fā)回調(diào)。

// In directive

link(scope) {

scope.$watch(() => readerService.status, (status) => {

scope.statusDisplay = STATUS_DISPLAY[status]

})

}

這個(gè)做法足夠簡(jiǎn)單高效,只要涉及 readerService.status 改變的代碼會(huì)觸發(fā) dirty-checking ,directive 就會(huì)自動(dòng)更新。service 不需要修改任何代碼。

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

// In directive

link(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

})

}

這種時(shí)候聲明式的編程風(fēng)格會(huì)更容易看懂,比如 Ember 或 Vue 里面的 computed property 。這個(gè)待會(huì)討論。

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

這種思路是 service 每次狀態(tài)改變都發(fā)送一個(gè)事件,然后 directive 監(jiān)聽事件來改變狀態(tài)。因?yàn)?directive 渲染的時(shí)候也許 status 已經(jīng)更新了。所以我們需要在 link 中計(jì)算一個(gè)初始值。

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

// In service

setStatus(value) {

this.status = value

// Need to inject $rootScope

this.$rootScope.$broadcast('reader.statusChanged', this.status)

}

// In directive

link(scope) {

scope.statusDisplay = STATUS_DISPLAY[nfcReaderService.status]

scope.$on('reader.statusChanged', (event, status) => {

scope.statusDisplay = STATUS_DISPLAY[status]

})

}

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

修改后的代碼如下:

// In service

setStatus(value) {

this.status = value

// Use $emit instead of $broadcast

this.$rootScope.$emit('reader.statusChanged', this.status)

}

// In directive

link(scope) {

scope.statusDisplay = STATUS_DISPLAY[nfcReaderService.status]

// Use $rootScope instead of scope

$rootScope.$on('reader.statusChanged', (event, status) => {

scope.statusDisplay = STATUS_DISPLAY[status]

})

}

如果因?yàn)槟承┰虿坏貌挥?$broadcast 的話,你可以在 $on 回調(diào)最后用 $digest 或 $apply 強(qiáng)制觸發(fā) dirty-checking ,這也可以達(dá)到快速更新 UI 的目的。

方法三:controller + property

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

// In directive

class 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 。只是因?yàn)?dirty-checking 的特性,綁定到 template 的屬性往往會(huì)多計(jì)算幾次。所以屬性必須非常簡(jiǎn)單。大部分情況下這不會(huì)有什么問題。

以上內(nèi)容是小編給大家介紹的Angular 根據(jù) service 的狀態(tài)更新 directive,希望對(duì)大家有所幫助!

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:Angular 根據(jù) service 的狀態(tài)更新 directive
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2026上岸·考公考編培訓(xùn)報(bào)班

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
性欧美xxxx视频在线观看| 亚洲精品美女免费| 美脚丝袜一区二区三区在线观看| 午夜精品久久久久久久久| 另类亚洲自拍| 欧美激情综合在线| 欧美特黄一级大片| 国产一区二区三区的电影| 亚洲国产欧美一区| 亚洲午夜免费福利视频| 久久免费观看视频| 欧美日韩一区二区三区在线看 | 亚洲经典三级| 亚洲欧美不卡| 欧美成人一二三| 国产欧美三级| 亚洲午夜视频| 欧美激情综合五月色丁香小说| 国产日韩欧美| 亚洲一级一区| 欧美激情第一页xxx| 韩日欧美一区二区| 午夜精品在线观看| 久久久无码精品亚洲日韩按摩| 欧美性淫爽ww久久久久无| 亚洲激情一区| 欧美mv日韩mv亚洲| 影音先锋另类| 久久综合狠狠| 亚洲高清免费视频| 欧美xart系列在线观看| 一区二区三区亚洲| 欧美在线视频一区二区| 国产欧美一区二区三区久久人妖 | 久久综合网络一区二区| 国产精品视频网站| 亚洲免费在线观看视频| 欧美午夜在线| 亚洲免费视频网站| 欧美亚州韩日在线看免费版国语版| 欧美精品久久久久久久久久| 影音先锋亚洲视频| 久久这里有精品视频| 黄色小说综合网站| 久久噜噜亚洲综合| 亚洲福利视频免费观看| 国产亚洲视频在线| 久久免费国产精品1| 亚洲高清视频在线观看| 免费成人高清视频| 亚洲精品一级| 欧美性猛交一区二区三区精品| 一本色道久久综合亚洲精品不卡| 欧美日韩精品久久久| 亚洲视频免费在线| 国产精品伦一区| 欧美影院在线| 亚洲电影免费在线观看| 欧美日本国产在线| 亚洲欧美久久久| 亚洲第一页中文字幕| 欧美美女视频| 欧美一进一出视频| 亚洲大黄网站| 欧美揉bbbbb揉bbbbb| 欧美一区二区成人6969| 在线看片日韩| 欧美日韩一区二区免费视频| 亚洲欧美激情一区二区| 在线观看视频亚洲| 欧美四级伦理在线| 久久久另类综合| av成人天堂| 国产亚洲va综合人人澡精品| 开心色5月久久精品| 99re热精品| 国模大胆一区二区三区| 欧美日韩另类字幕中文| 久久久av毛片精品| 亚洲香蕉网站| 亚洲三级影院| 伊人蜜桃色噜噜激情综合| 欧美精品久久99| 久久久久久尹人网香蕉| 亚洲天堂成人| 亚洲国产综合在线| 国产精品区一区二区三| 欧美激情一区二区三区成人| 久久国产精品毛片| 亚洲视频在线播放| 亚洲精品免费一二三区| 一区二区三区在线观看欧美| 欧美性片在线观看| 欧美区在线播放| 老牛影视一区二区三区| 午夜精品福利电影| 9色porny自拍视频一区二区| 激情亚洲一区二区三区四区| 国产麻豆9l精品三级站| 欧美日韩在线电影| 欧美激情第三页| 欧美在线国产| 一区二区三区导航| 亚洲午夜av| 亚洲天堂av在线免费| 一区二区欧美在线| 亚洲午夜黄色| 亚洲免费影视| 久久国产精品久久久久久电车| 亚洲一区二区三区在线| 亚洲一区二区影院| 欧美伊人久久| 久久综合国产精品| 欧美精品免费在线观看| 欧美日韩在线视频一区| 欧美日韩国产麻豆| 欧美日韩mp4| 国产精品爽爽爽| 国产精品自拍视频| 国产一区二区三区不卡在线观看| 国产精品麻豆欧美日韩ww| 国产精品综合| 国产午夜亚洲精品理论片色戒| 韩国三级电影一区二区| 国产一区二区无遮挡| 国产女主播在线一区二区| 国产性色一区二区| 国产精品高清在线| 国产精品高清在线观看| 欧美 日韩 国产一区二区在线视频| 久久精品成人一区二区三区蜜臀 | 国产精品综合视频| 欧美成人第一页| 久久久xxx| 一本一本久久a久久精品综合妖精| 激情成人综合| 国产喷白浆一区二区三区| 欧美大色视频| 久久久精品视频成人| 午夜天堂精品久久久久 | 亚洲国产精品va在线看黑人| 国产精品久久久一区二区三区| 欧美日韩国产色综合一二三四| 欧美成人在线影院| 免费欧美视频| 你懂的成人av| 欧美顶级少妇做爰| 欧美成人激情视频免费观看| 久久综合一区二区| 欧美视频三区在线播放| 欧美日韩精品高清| 国产精品久久久久高潮| 国产精品mv在线观看| 欧美成人午夜影院| 欧美成人官网二区| 免费成人高清在线视频| 亚洲第一天堂av| 久久免费偷拍视频| 欧美日本国产一区| 欧美乱在线观看| 欧美激情综合色| 欧美日韩亚洲综合一区| 国产精品mm| 国产日韩亚洲| 国产精品白丝av嫩草影院| 在线观看日韩www视频免费| 亚洲激情小视频| 亚洲人午夜精品| 日韩午夜激情av| 午夜欧美精品久久久久久久| 久久er99精品| 亚洲欧美不卡| 久久久久国色av免费观看性色| 亚洲一区二区在线播放| 欧美精品在线观看| 久久亚洲精品中文字幕冲田杏梨| 亚洲美女淫视频| 久久激五月天综合精品| 在线看片日韩| 欧美日韩爆操| 欧美精品日韩综合在线| 欧美一区二区女人| 一区二区三区免费看| 国产日韩欧美在线| 国产欧美亚洲日本| 国产欧美日韩综合精品二区| 亚洲女女做受ⅹxx高潮| 免费日韩视频| 欧美日韩亚洲国产一区| 国产精品高清免费在线观看| 欧美日韩精品欧美日韩精品| 国产精品免费在线| 国内欧美视频一区二区| 亚洲深夜福利视频| 欧美一区二区三区久久精品茉莉花 | 欧美国产日韩在线观看| 欧美日韩国产999| 国产欧美一区二区三区国产幕精品| 欧美日本一道本| 欧美激情精品久久久六区热门|