AngularJS中$apply方法和$watch方法用法總結(jié)
本文實(shí)例總結(jié)了AngularJS中$apply方法和$watch方法用法。分享給大家供大家參考,具體如下:
引言
最近在項(xiàng)目中封裝控件的時候用到了$watch方法來監(jiān)聽module中的值的變化,當(dāng)時小編對這個方法不是很了解,所以在網(wǎng)上找了一些資料來學(xué)習(xí)一下,下面小編就給大家簡單介紹一些AngularJS中Scope 提供$apply 方法傳播Model 的變化和$watch方法監(jiān)聽module變化。
$apply使用情景
AngularJS 外部的控制器(DOM 事件、外部的回調(diào)函數(shù)如 jQuery UI 空間等)調(diào)用了AngularJS 函數(shù)之后,必須調(diào)用$apply。在這種情況下,你需要命令 AngularJS 刷新自已(模型、視圖等),$apply就是用來做這件事情的。我們在使用$apply這個方法的時候,只要可以,請把要執(zhí)行的代碼和函數(shù)傳遞給$apply 去執(zhí)行,而不要自已執(zhí)行那些函數(shù)然后再調(diào)用$apply。
下面看一個Demo,寫一個定時器在兩秒以后改變name的值:
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>RunJS</title> <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> <script src="http://cdn.bootcss.com/angular.js/1.2.9/angular-route.min.js"></script> <script src="serviceJS01.js"></script> </head> <body ng-app="myApp" > <div ng-controller="firstController" ng-click="show()"> {{name}} {{age}} </div> </body> </html> <script> var app = angular.module("myApp",[]); app.controller('firstController',function($scope,$timeout){ setTimeout(function(){ $scope.$apply(function(){ $scope.name="李四"; }) },2000); $scope.name="張三"; $scope.age='10'; $scope.show=function(){ $scope.name='點(diǎn)擊后的name'; } $timeout(function(){ $scope.age='50'; },2000); }) </script>
在上面代碼中如果我們不使用$apply來傳播name值的改變,而是直接將$scope.name="李四"這句代碼寫在setTimeout函數(shù)中,界面上顯示的值根本就不會改變。
$watch方法監(jiān)聽module變化
當(dāng)你的數(shù)據(jù)模型中某一部分發(fā)生變化時,$watch 函數(shù)可以向你發(fā)出通知。你可以監(jiān)控單個對象的屬性,也可以監(jiān)控需要經(jīng)過計(jì)算的結(jié)果(函數(shù)),實(shí)際上只要能夠被當(dāng)作屬性訪問到,或者可以當(dāng)作一個JavaScript 函數(shù)被計(jì)算出來,就可以被$watch 函數(shù)監(jiān)控。它的函數(shù)簽名為:
$watch(watchFn, watchAction, deepWatch)
watchFn參數(shù):這個是我們監(jiān)聽地方目標(biāo)對象,它是一個帶有angular表達(dá)式或者函數(shù)的字符串;
watchAction參數(shù):這是一個函數(shù)或者表達(dá)式,當(dāng)watchFn 發(fā)生變化時會被調(diào)用。如果是函數(shù)的形式,它將會接收到watchFn 的新舊兩個值,以及作用域?qū)ο蟮囊谩F浜瘮?shù)簽名為function(newValue, oldValue, scope)。
deepWatch參數(shù):如果設(shè)置為true,這個可選的布爾型參數(shù)將會命令A(yù)ngular 去檢查被監(jiān)控對象的每個屬性是否發(fā)生了變化。如果你想要監(jiān)控?cái)?shù)組中的元素,或者對象上的所有屬性,而不只是監(jiān)控一個簡單的值,你就可以使用這個參數(shù)。
下面看一個Demo,當(dāng)費(fèi)用超過100的時候,運(yùn)費(fèi)為0否則運(yùn)費(fèi)為10:
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>RunJS</title> <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> <script src="http://cdn.bootcss.com/angular.js/1.2.9/angular-route.min.js"></script> <script src="serviceJS01.js"></script> </head> <body ng-app="myApp" > <div ng-controller="firstController" ng-click="show()"> <p>價(jià)格:<input type="text" ng-model="iphone.money"></p> <p>個數(shù):<input type="text" ng-model="iphone.num"></p> <p>費(fèi)用: <span>{{sum() | currency:'¥'}}</span></p> <p>運(yùn)費(fèi): <span>{{iphone.fre | currency:'¥'}}</span></p> <p>總額: <span>{{sum() + iphone.fre | currency:'¥'}}</span></p> </div> </body> </html> <script> var app = angular.module("myApp",[]); app.controller('firstController',function($scope){ $scope.iphone={ money:5, num:1, fre:10 }; $scope.sum=function(){ return $scope.iphone.money * $scope.iphone.num; } $scope.$watch($scope.sum,function(newValue,oldValue){ $scope.iphone.fre=newValue>=100?0:10 }) }) </script>
$watch這個函數(shù)在項(xiàng)目中會經(jīng)常用到,所以我們需要對這個函數(shù)靈活的掌握,這樣我們在自定控件或者完成一些比較復(fù)雜的需求的時候很更加的方便。
小結(jié)
以上是小編對中兩個方法的總結(jié),這些都是比較入門的知識,如果想更好的對這些知識了解還需要我們在項(xiàng)目中好好的研究。
源碼地址:http://runjs.cn/code/ovjwuxhn
更多關(guān)于AngularJS相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《AngularJS入門與進(jìn)階教程》及《AngularJS MVC架構(gòu)總結(jié)》
希望本文所述對大家AngularJS程序設(shè)計(jì)有所幫助。
相關(guān)文章
Angular之jwt令牌身份驗(yàn)證的實(shí)現(xiàn)
這篇文章主要介紹了Angular之jwt令牌身份驗(yàn)證的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02angularjs實(shí)現(xiàn)多張圖片上傳并預(yù)覽功能
這篇文章主要為大家詳細(xì)介紹了angularjs實(shí)現(xiàn)多張圖片上傳并預(yù)覽功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02AngularJS 雙向數(shù)據(jù)綁定詳解簡單實(shí)例
這篇文章主要介紹了AngularJS 雙向數(shù)據(jù)綁定詳解簡單實(shí)例的相關(guān)資料,需要的朋友可以參考下2016-10-10AngularJS+bootstrap實(shí)現(xiàn)動態(tài)選擇商品功能示例
這篇文章主要介紹了AngularJS+bootstrap實(shí)現(xiàn)動態(tài)選擇商品功能,涉及AngularJS指令、事件響應(yīng)及頁面元素動態(tài)操作相關(guān)技巧,需要的朋友可以參考下2017-05-05angularjs ocLazyLoad分步加載js文件實(shí)例
本篇文章主要介紹了angularjs ocLazyLoad分步加載js文件,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01Angular 中使用 FineReport不顯示報(bào)表直接打印預(yù)覽
這篇文章主要介紹了Angular 中使用 FineReport不顯示報(bào)表直接打印預(yù)覽,非常不錯,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08Angular實(shí)現(xiàn)的table表格排序功能完整示例
這篇文章主要介紹了Angular實(shí)現(xiàn)的table表格排序功能,結(jié)合完整實(shí)例形式分析了AngularJS表格排序所涉及的事件響應(yīng)、元素遍歷、屬性修改等相關(guān)操作技巧,需要的朋友可以參考下2017-12-12Angular4實(shí)現(xiàn)圖片上傳預(yù)覽路徑不安全的問題解決
這篇文章主要給大家介紹了關(guān)于Angular4實(shí)現(xiàn)圖片上傳預(yù)覽路徑不安全問題的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧。2017-12-12AngularJS實(shí)現(xiàn)元素顯示和隱藏的幾個案例
這篇文章主要介紹了AngularJS實(shí)現(xiàn)元素顯示和隱藏的幾個案例,需要的朋友可以參考下2015-12-12