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

首頁 > 網站 > WEB開發 > 正文

(2)AngularJS 1.X 之和數據綁定相關的指令

2024-04-27 15:06:40
字體:
來源:轉載
供稿:網友

引言和數據綁定相關指令1 代碼實現2 代碼解釋雙向綁定是如何實現的1 雙向綁定原理watch 隊列2 雙向綁定原理digest循環3 雙向綁定原理apply方法總結

1.引言

      在上一篇博客中我們介紹了兩個指令,一個是ng-app,另外一個是ng-init,其中前一個是指令angularjs的作用域,第二個指令是設置angular初始化變量的,在本片博客中,我們將會介紹一下和數據綁定相關的指令,其中一個是ng-model,另外一個是ng-bind。

2.和數據綁定相關指令

      我們通過html輸出數據可以通過兩種方式,一種是通過表達式,一個是可以通過ng-bind指令,如何將我們的數據綁定到angularjs的變量呢?我們可以通過ng-model指令,ng-model指令可以實現雙向綁定,也就是說:如果我們通過ng-model修改了變量的值,將會直接修改到html。

2.1 代碼實現

首先我們引入angular文件<script src="js/angular.js"></script>我們創建一個input標簽,然后綁定到angular變量上<html ng-app><head> <script src="js/angular.js"></script></head><body> <input type="text" ng-model="test"><br> {{test}}<br> <div ng-bind="test"></div></body></html>運行結果

這里寫圖片描述

2.2 代碼解釋

我們通過ng-model指令創建了一個變量test然后我們通過{{}}表達式,輸出了test變量

我們通過標簽輸出了test變量,注意,當我們使用ng-bind指令時,實際上是添加了innerHTML屬性,如下圖所示 這里寫圖片描述

ng-bind指令相對于{{}}(表達式)的優勢,當瀏覽器加載比較慢的時候,瀏覽器會出現{{}}符合,而ng-bind不會出現

3 雙向綁定是如何實現的

      在上面的程序的時候,我們肯定會有一個疑問:為什么我們輸入文本框,下面的信息會相應改變呢?也就是說雙向綁定是如何實現的?接下來我們就用文字描述一下雙向綁定是如何實現的?

3.1 雙向綁定原理($watch 隊列

      在angularjs中有一個$watch 隊列的概念,$watch 隊列中存放一系列的$watch對象,那么$watch對象是如何產生的呢?每當我們綁定數據到UI上時,會自動生成一個$watch對象,然后將$watch對象存放到$watch 隊列中,如下面的代碼:

User: <input type="text" ng-model="user" />PassWord: <input type="password" ng-model="pass" />

代碼中生成了兩個變量每一個是user,一個是pass,該變量綁定到了UI上,因此會自動生成兩個$watch對象,然后存放到$watch 隊列中。

接下來我們再看第二段的代碼:

app.controller('MainCtrl', function($scope) { $scope.foo = "Foo"; $scope.world = "World";});Hello, {{ world}}

這里,即便我們在$scope上添加了兩個變量,但是只有一個綁定在了UI上,因此在這里只生成了一個$watch對象。

3.2 雙向綁定原理($digest循環)

      瀏覽器一直在等待事件,比如用戶交互。假如你點擊一個按鈕或者在輸入框里輸入東西,事件的回調函數就會在javascript解釋器里執行,然后你就可以做任何DOM操作,等回調函數執行完畢時,瀏覽器就會相應地對DOM做出變化。 Angular拓展了這個事件循環,生成一個angular context的執行環境。當瀏覽器接收到可以被angular context處理的事件時,$digest循環就會觸發。$digest循環是由兩個更小的循環組合起來的。一個處理evalAsync隊列,另一個處理$watch隊列,$digest將會遍歷我們的$watch隊列,通過$watch隊列來觀察我們UI中變量值是否已經發生了改變,通過$watch隊列來觀察我們UI中變量值是否已經發生了改變,通過$watch隊列來觀察我們UI中變量值是否已經發生了改變(重要的話說三遍)如果$watch隊列發生了改變,那么當$digest循環結束時,DOM相應地變化。從而實現了數據的雙向綁定。

3.3 雙向綁定原理($apply方法)

      這時候我們又會有一個問題:什么事件可以被angular context處理呢?答案是$apply方法,我們是通過$apply方法啟動$digest循環,只要$digest循環被執行,DOM元素就會被更新,假設我們有這么一個輸入框ng-model="foo",然后我們輸入一個f ,實際上是這么執行的$apply("foo = 'f';"),也就是ng-model指令幫我們自動調用了$apply方法。       在上面的例子中$apply方法是自動調用的,同樣我們可以人為的調用$apply方法,這將在以后的博客中介紹。同樣我們可以人為的創建$watch,然后將其添加到$watch隊列中,這也將在以后的博客中介紹

4.總結

      在本篇博客中介紹了和數據綁定相關的指令,主要介紹了ng-model,ng-bind,還用文字介紹了數據的雙向綁定是如何實現的。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
操日韩av在线电影| 91在线视频九色| 精品视频在线播放免| 欧美激情在线狂野欧美精品| 亚洲精品动漫100p| 国产精品亚洲аv天堂网| 亚洲一区二区国产| 伊人青青综合网站| 欧美日韩国产精品一区二区三区四区| xvideos亚洲| 日韩电影免费观看在线| 欧美电影免费观看电视剧大全| 亚洲一区999| 欧美另类老肥妇| 中文字幕亚洲专区| 操91在线视频| 97免费在线视频| 深夜福利91大全| 亚洲成年人在线| 亚洲自拍小视频| 欧美激情按摩在线| 欧美日韩国产va另类| 久久国产精品电影| 欧美麻豆久久久久久中文| 国产在线999| 久久777国产线看观看精品| 久久精品免费播放| 国产精品久久久久久久久久新婚| 日韩在线视频免费观看| 欧美一级淫片aaaaaaa视频| 78色国产精品| 免费不卡欧美自拍视频| 亚洲人av在线影院| 成人国内精品久久久久一区| 国产成人福利网站| 日本不卡免费高清视频| 亚洲精品国产欧美| 亚洲 日韩 国产第一| 久久精品亚洲热| 国内精品久久久久久中文字幕| 成人av色在线观看| 91精品在线影院| 欧美在线观看一区二区三区| 亚洲香蕉av在线一区二区三区| 亚洲色图欧美制服丝袜另类第一页| 亚洲午夜女主播在线直播| 一道本无吗dⅴd在线播放一区| 亚洲国产97在线精品一区| 青青青国产精品一区二区| 成人a级免费视频| 久久资源免费视频| 亚洲精品小视频| 一区二区亚洲欧洲国产日韩| 国产精品视频中文字幕91| 亚洲综合最新在线| 成人性生交大片免费观看嘿嘿视频| 九九精品在线视频| 97视频免费在线看| 亚洲色在线视频| 亚洲欧美国产精品专区久久| 亚洲成人亚洲激情| 国产精品成人va在线观看| 色噜噜久久综合伊人一本| 亚洲老头同性xxxxx| 日韩亚洲成人av在线| 亚洲黄色www网站| 久久躁狠狠躁夜夜爽| 91国产视频在线播放| 色综合亚洲精品激情狠狠| 91在线观看免费高清| 日韩电影中文 亚洲精品乱码| 中文字幕亚洲综合| 久久久久久久久久久人体| 色777狠狠综合秋免鲁丝| 亚洲福利视频网站| 中文字幕亚洲精品| 成人免费黄色网| 精品偷拍各种wc美女嘘嘘| 亚洲精品在线不卡| 欧美www在线| 亚洲精品资源美女情侣酒店| 久久成人精品电影| 亚洲电影成人av99爱色| 性亚洲最疯狂xxxx高清| 性欧美xxxx交| 亚洲欧美中文日韩在线v日本| 美日韩丰满少妇在线观看| 久久久黄色av| 黑丝美女久久久| 91久久在线视频| 欧美一区二粉嫩精品国产一线天| x99av成人免费| 在线观看成人黄色| 欧美亚洲视频在线看网址| 日韩中文字幕第一页| 久久久精品国产亚洲| 国产一区二区av| 原创国产精品91| 久久影视电视剧凤归四时歌| 国产激情久久久| 亚洲嫩模很污视频| 91亚洲国产成人精品性色| 欧美激情欧美狂野欧美精品| 亚洲激情视频在线播放| 久久视频免费观看| 原创国产精品91| 欧美激情精品久久久久久变态| 一区二区三区视频免费在线观看| 中文日韩在线视频| 亚洲国产精久久久久久| 久久综合免费视频影院| 久久99热精品| 91精品在线播放| 亚洲欧洲国产一区| 亚洲欧美日韩中文在线制服| 日韩欧美精品网址| 国产精品久久久久久久久久久久| 91精品久久久久久久久久另类| 欧洲永久精品大片ww免费漫画| 久久九九国产精品怡红院| 国产精品扒开腿做爽爽爽的视频| 久久久999国产精品| 夜夜嗨av色一区二区不卡| 久久久久国产精品免费| 亚洲少妇中文在线| 久久6免费高清热精品| 日本久久久久久久| 国产69精品久久久久99| 欧美日韩国产精品专区| 亚洲国产精品久久久久秋霞不卡| 欧美日韩裸体免费视频| 中文字幕免费精品一区高清| 久久香蕉国产线看观看网| 亚洲新中文字幕| 北条麻妃一区二区在线观看| 亚洲自拍偷拍色片视频| 97超级碰碰人国产在线观看| 色av中文字幕一区| 亚洲精品一区二区三区婷婷月| 狠狠躁夜夜躁人人爽天天天天97| 欧美超级乱淫片喷水| 国产精品免费电影| 欧美午夜丰满在线18影院| 欧美黑人狂野猛交老妇| 日韩大片免费观看视频播放| 91精品久久久久| 亚洲护士老师的毛茸茸最新章节| 精品毛片三在线观看| 亚洲性生活视频在线观看| 精品国产拍在线观看| 性欧美视频videos6一9| 欧美视频专区一二在线观看| 亚洲字幕在线观看| 中文字幕亚洲专区| 亚洲欧洲激情在线| 欧美成人sm免费视频| 亚洲最大的av网站| 亚洲国产成人91精品| 日韩高清免费观看| 最新国产成人av网站网址麻豆| 欧美夫妻性生活视频| 97香蕉超级碰碰久久免费的优势| 色偷偷av一区二区三区乱| 91老司机精品视频|