欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Angular.js中ng-if、ng-show和ng-hide的區(qū)別介紹

 更新時(shí)間:2017年01月20日 14:45:36   作者:小易的博客  
angularJS中的ng-show、ng-hide、ng-if指令都可以用來控制dom元素的顯示或隱藏。那么這篇文章就給大家主要介紹了Angular.js中ng-if、ng-show和ng-hide的區(qū)別,需要的朋友可以參考借鑒,下面來一起看看吧。

前言

大家都知道在使用anularjs開發(fā)前端頁(yè)面時(shí),常常使用ng-show、ng-hide、ng-if功能來控制頁(yè)面元素的顯示或隱藏,那他們之間有什么不同呢?下面通過這篇文章來一起看看吧。

實(shí)現(xiàn)原理

ng-show/ng-hide是通過修改CSS樣式方式控制元素顯示與隱藏,對(duì)應(yīng)的DOM元素會(huì)一直存在于當(dāng)前頁(yè)面中,而ng-if根據(jù)表達(dá)式的值動(dòng)態(tài)的在當(dāng)前的頁(yè)面中添加刪除頁(yè)面元素。如果賦值表達(dá)式的值為false,那么這個(gè)元素就會(huì)從頁(yè)面中刪除,否則會(huì)添加一個(gè)元素。ng-if創(chuàng)建元素時(shí)用的是被它編譯后的代碼,如果ng-if內(nèi)部的代碼被其它方式修改過,那么修改只會(huì)對(duì)本次展現(xiàn)有效,頁(yè)面元素重新渲染后修改效果會(huì)消失,而ng-show/ng-hide則能夠保留dom元素上次修改后的狀態(tài)。

在作用域方面,兩者也存在差異:當(dāng)一個(gè)元素被ng-if從DOM中刪除時(shí),與其關(guān)聯(lián)的作用域也會(huì)被銷毀。而且當(dāng)它重新加入DOM中時(shí),則會(huì)生成一個(gè)新的作用域,而ng-show和ng-hide則不會(huì)。

通過如下代碼并結(jié)合瀏覽器開發(fā)者工具可以清楚的看出二者之間的不同:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" ng-app="app">
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
 <title>ng-if ng-show ng-hide</title>
 <script type="text/javascript" class="library" src="http://libs.useso.com/js/angular.js/1.2.9/angular.min.js"></script>
 </head>
<body>
 <div ng-controller="MainCtrl">
  <div ng-show="false">
   ng-show = false 
  </div>
  <div ng-show="true">
  ng-show=true 
  </div>
  <div ng-if="true">
  ng-if = true
  </div>
  <div ng-if="false">
  ng-if = false
  </div>
 </div>
 </body>
</html>

js

angular.module("app",[]).controller("MainCtrl",function($scope){
});

頁(yè)面最終的HTML片斷如下:

<div ng-controller="MainCtrl" class="ng-scope">
 <div ng-show="false" class="ng-hide">
 ng-show = false 
 </div>
 <div ng-show="true" class="">
 ng-show=true 
 </div>
 <!-- ngIf: true --><div ng-if="true" class="ng-scope">
 ng-if = true
 </div><!-- end ngIf: true -->
 <!-- ngIf: false -->
</div>

由于ng-if/ng-hide(ng-show)在原理上有很大的差別,所以在某些情況下展示出來的效果有較大的差別。

正確使用ng-if和ng-show

在使用bootstrap中,我們會(huì)經(jīng)常用到按鈕組,也就是btn-group,如果仔細(xì)觀察的話,會(huì)發(fā)現(xiàn)一個(gè)按鈕組的第一個(gè)和最后一個(gè)按鈕分別是有圓角的,如下圖:

但是中間的按鈕是沒有圓角的,這樣顯得比較美觀。

在結(jié)合angular使用過程中,有時(shí)候需要根據(jù)一些條件來隱藏掉一些按鈕,當(dāng)隱藏第一個(gè)或最后一個(gè)按鈕時(shí),會(huì)出現(xiàn)一些小問題。

代碼:

 <div class="row" ng-controller='myCtrl'>
  <div class="col-lg-offset-1">
  <div class="btn-group">
   <button class='btn btn-primary'>button1</button>
   <button class='btn btn-primary'>button2</button>
   <button class='btn btn-primary' ng-show='false'>button3</button>
  </div>
  </div>
 </div>

效果如圖:

我們發(fā)現(xiàn)button2的圓角不見了,這和我們預(yù)期的效果不一致。

問題是由ng-show引起的,而我們知道ng-show只是改變?cè)氐膁isplay屬性,所以我們把這個(gè)ng-show='false'改成 style='display:none' 的話也會(huì)有這個(gè)圓角消失的效果。

那么我們應(yīng)該怎么做,才會(huì)讓它顯示圓角呢?

如果我們想要達(dá)到顯示圓角的效果,那么我們應(yīng)該用ng-if ,只需要將代碼中的ng-show='false' 改成ng-if='false' 即可。

原因是:ng-if會(huì)根據(jù)表達(dá)式的值來決定當(dāng)前這個(gè)DOM元素的創(chuàng)建與銷毀。當(dāng)表達(dá)式為返回true時(shí),創(chuàng)建,反之,則銷毀。銷毀就意味著這個(gè)DOM元素從頁(yè)面中刪除了。

效果如圖:

圓角顯示了,證明button3已經(jīng)從頁(yè)面中刪除了。

再進(jìn)一步,我們打開開發(fā)者工具也可以發(fā)現(xiàn)這個(gè)DOM元素確實(shí)已經(jīng)不存在了:

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

相關(guān)文章

  • AngularJS學(xué)習(xí)筆記之表單驗(yàn)證功能實(shí)例詳解

    AngularJS學(xué)習(xí)筆記之表單驗(yàn)證功能實(shí)例詳解

    這篇文章主要介紹了AngularJS學(xué)習(xí)筆記之表單驗(yàn)證功能,結(jié)合實(shí)例形式分析了AngularJS針對(duì)表單的校驗(yàn)、監(jiān)控等相關(guān)操作技巧,需要的朋友可以參考下
    2017-07-07
  • Angular 中 select指令用法詳解

    Angular 中 select指令用法詳解

    這篇文章主要介紹了Angular 中 select指令用法詳解的相關(guān)資料,本文介紹的非常詳細(xì),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-09-09
  • AngularJS基礎(chǔ) ng-href 指令用法

    AngularJS基礎(chǔ) ng-href 指令用法

    本文主要介紹AngularJS ng-href 指令,這里對(duì)ng-href 基礎(chǔ)資料進(jìn)行詳細(xì)介紹,并附代碼實(shí)例,有興趣的小伙伴可以參考下
    2016-08-08
  • 使用Angular CLI生成路由的方法

    使用Angular CLI生成路由的方法

    這篇文章主要介紹了使用Angular CLI生成路由的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-03-03
  • AngulerJS學(xué)習(xí)之按需動(dòng)態(tài)加載文件

    AngulerJS學(xué)習(xí)之按需動(dòng)態(tài)加載文件

    本篇文章主要介紹了AngulerJS學(xué)習(xí)之按需動(dòng)態(tài)加載文件,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-02-02
  • AngularJs 國(guó)際化(I18n/L10n)詳解

    AngularJs 國(guó)際化(I18n/L10n)詳解

    本文主要介紹AngularJs 國(guó)際化的知識(shí),這里整理了詳細(xì)的資料來講解國(guó)際化,有需要的小伙伴可以參考下
    2016-09-09
  • angularJS提交表單(form)

    angularJS提交表單(form)

    這篇文章主要介紹了angularJS提交表單(form)的方法和示例,需要的朋友可以參考下
    2015-02-02
  • Angular.js實(shí)現(xiàn)多個(gè)checkbox只能選擇一個(gè)的方法示例

    Angular.js實(shí)現(xiàn)多個(gè)checkbox只能選擇一個(gè)的方法示例

    這篇文章主要給大家介紹了利用Angular.js實(shí)現(xiàn)多個(gè)checkbox只能選擇一個(gè)的方法,文中給出了詳細(xì)的示例代碼,相信對(duì)大家具有一定的參考價(jià)值,下面來一起看看吧。
    2017-02-02
  • AngularJS中ng-class用法實(shí)例分析

    AngularJS中ng-class用法實(shí)例分析

    這篇文章主要介紹了AngularJS中ng-class用法,結(jié)合實(shí)例形式分析了ng-class的功能、使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2017-07-07
  • angular + express 實(shí)現(xiàn)websocket通信

    angular + express 實(shí)現(xiàn)websocket通信

    最近需要實(shí)現(xiàn)一個(gè)功能,后端通過TCP協(xié)議連接雷達(dá)硬件的控制器,前端通過websocket連接后端,當(dāng)控制器觸發(fā)消息的時(shí)候,把信息通知給所以前端,本文給的大家講解angular + express 實(shí)現(xiàn)websocket通信的思路,感興趣的朋友一起看看吧
    2023-09-09

最新評(píng)論