ng-bind和{{}} ng-model區(qū)別

AngularJS的數(shù)據(jù)綁定有 ng-bind 和 ng-model :
ng-bind是從 scope?>view的單向綁定;{{}}是scope?>view的單向綁定;ng?modle是scope <-> view 的雙向綁定。
ng-bind和{ { } }的區(qū)別
在AngularJS中顯示模型中的數(shù)據(jù)有兩種方式:
一種是使用花括號(hào)插值的方式:

<h1>{{ text }}</h1>1

另一種是使用基于屬性的指令,叫做ng-bind:

<h1 ng-bind = "text"></h1>1

這兩種方式顯示出的效果是一樣的,主要的區(qū)別和解決方法:

1、ngBind只能單個(gè)綁定變量,而{{ }}可以多個(gè)綁定變量;

<h1>{{ text }}{{ text }}</h1>1

解決方法:
使用ng-bind-template可以綁定一個(gè)模板,模板中可以包含多個(gè)AngularJS的表達(dá)式:“{{expression}}”;

<h1 ng-bind-template ="{{text}} {{text}}" ></h1>1

2、在使用{{ }}時(shí)因?yàn)榧虞d順序的原因,可能在頁(yè)面顯示的時(shí)候會(huì)有“閃爍”現(xiàn)象,這是因?yàn)閧{}}在加載的時(shí)候,若網(wǎng)速不好或者首頁(yè)還未加載angular庫(kù)時(shí),其會(huì)顯示出來(lái),然后等到AngularJS才能把它解析成原本應(yīng)該顯示的內(nèi)容,所以一般建議ng-bind在首頁(yè)加載的時(shí)候使用,{{}}建議是首頁(yè)意外的頁(yè)面使用。
解決方法:
添加 ng-cloak 指令:該指令用于在 AngularJS 應(yīng)用在加載時(shí)防止 AngularJS 代碼未加載完而出現(xiàn)的問(wèn)題。

<h1 ng-cloak>{{ text }}</h1>1

ng-modle是完成 $scope <-> view 的雙向綁定。
ng-model指令的作用是把輸入型的元素(input,select,textarea等)和scope中的數(shù)據(jù)進(jìn)行綁定的作用,也可以用在自定義的form元素上。ng-model指令需要和input、select等指令進(jìn)行配合使用。當(dāng)在元素加上ng-model指令后,框架會(huì)負(fù)責(zé)元素和msg變量的自動(dòng)同步。

<input type="text" ng-model= "msg">
<h1>{{msg}}</h1>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容