關(guān)于angularJs指令的Scope(作用域)介紹
每當一個指令被創(chuàng)建的時候,都會有這樣一個選擇,是繼承自己的父作用域(一般是外部的Controller提供的作用域或者根作用域($rootScope)),還是創(chuàng)建一個新的自己的作用域,當然AngularJS為我們指令的scope參數(shù)提供了三種選擇,分別是:false,true,{};默認情況下是false。
1.scope = false
JS 代碼:
html 代碼:
result:
修改文本框的內(nèi)容,兩個名字都會變,實際上修改的是同一個$scope的name屬性。
2. scope=true
修改上面的JS代碼,將指令中的:scope:false修改為scope:true
然后我們再試著在我們的input輸入框中寫一些字符串,會發(fā)現(xiàn),指令中的那個name發(fā)生了變化,但是指令外的那個name卻沒有發(fā)生變化,這說明了一個問題。
當我們將scope設(shè)置為true的時候,我們就新創(chuàng)建了一個作用域,只不過這個作用域是繼承了我們的父作用域;我覺得可以這樣理解,我們新創(chuàng)建的作用域是一個新的作用域,只不過在初始化的時候,用了父作用域的屬性和方法去填充我們這個新的作用域。它和父作用域不是同一個作用域。
當我們將scope設(shè)置為false的時候,我們創(chuàng)建的指令和父作用域(其實是同一個作用域)共享同一個model模型,所以在指令中修改模型數(shù)據(jù),它會反映到父作用域的模型中。
3. scope={}
當我們將scope設(shè)置為{}時,意味著我們創(chuàng)建的一個新的與父作用域隔離的新的作用域,這使我們在不知道外部環(huán)境的情況下,就可以正常工作,不依賴外部環(huán)境。
JS代碼:
html代碼:
result:
修改文本框內(nèi)容只有指令中的名字會被修改.
scope: {@=&}
@
這是一個單項綁定的前綴標識符
使用方法:在元素中使用屬性,好比這樣<div my-directive my-name="{{name}}"></div>,注意,屬性的名字要用-將兩個單詞連接,因為是數(shù)據(jù)的單項綁定所以要通過使用{{}}來綁定數(shù)據(jù)。
=
這是一個雙向數(shù)據(jù)綁定前綴標識符
使用方法:在元素中使用屬性,好比這樣<div my-directive age="age"></div>,注意,數(shù)據(jù)的雙向綁定要通過=前綴標識符實現(xiàn),所以不可以使用{{}}。
&
這是一個綁定函數(shù)方法的前綴標識符
使用方法:在元素中使用屬性,好比這樣<div my-directive change-my-age="changeAge()"></div>,注意,屬性的名字要用-將多個個單詞連接。
以上就是小編為大家?guī)淼年P(guān)于angularJs指令的Scope(作用域)介紹全部內(nèi)容了,希望大家多多支持腳本之家~
相關(guān)文章
AngularJS select設(shè)置默認值的實現(xiàn)方法
這篇文章主要介紹了AngularJS select設(shè)置默認值的實現(xiàn)方法的相關(guān)資料,這里提供實現(xiàn)方法幫助大家實現(xiàn)這樣的功能,需要的朋友可以參考下2017-08-08Angular將填入表單的數(shù)據(jù)渲染到表格的方法
這篇文章主要介紹了Angular將填入表單的數(shù)據(jù)渲染到表格的方法,非常具有實用價值,需要的朋友可以參考下2017-09-09AngularJS利用Controller完成URL跳轉(zhuǎn)
本文的主要內(nèi)容是介紹在AngularJS中怎樣利用Controller實現(xiàn)URL跳轉(zhuǎn),本文給出了實例代碼,簡單明了,有需要的可以參考學(xué)習(xí)。2016-08-08AngularJs的$http發(fā)送POST請求,php無法接收Post的數(shù)據(jù)問題及解決方案
這篇文章主要介紹了AngularJs的$http發(fā)送POST請求,php無法接收Post的數(shù)據(jù)的問題及解決方案,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-08在 Angular-cli 中使用 simple-mock 實現(xiàn)前端開發(fā) API Mock 接口數(shù)據(jù)模擬功能的方法
這篇文章主要介紹了在 Angular-cli 中使用 simple-mock 實現(xiàn)前端開發(fā) API Mock 接口數(shù)據(jù)模擬功能的方法,需要的朋友可以參考下2018-11-11Angularjs自定義指令實現(xiàn)分頁插件(DEMO)
由于最近的一個項目使用的是angularjs1.0的版本,涉及到分頁查詢數(shù)據(jù)的功能,后來自己就用自定義指令實現(xiàn)了該功能,下面小編把實例demo分享到腳本之家平臺,需要的朋友參考下2017-09-09