這次帶給大家vue中v-if與v-show使用和區別,vue中v-if與v-show使用的注意事項有哪些,以下就是實戰案例,一起來看一下。
v-if 和v-show 的區別
v-if只會在滿足條件時才會編譯,而v-show不管是否滿足條件總是會編譯,v-show的顯示與隱藏只是簡單的切換CSS的display屬性。
也就是說,在使用v-if時,若值為false,那麼頁面將不會有這個html標籤產生。而v-show:不論其值是false還是true,html元素都會存在,只是簡單的切換css的display屬性。
使用場景
一般來說,v-if 有較高的切換消耗而v-show 有較高的初始渲染消耗。因此,如果需要頻繁切換 v-show 較好,如果在運行時條件不大可能改變 v-if 較好。
另外
1.v-if 指令可以套用在template包裝元素上,而v-show不支援template
# 2.將v-show應用在元件上時,因為指令的優先權v-else 會出現問題,解決方法就是用另一個v-show 取代v-else
// 错误 <custom-component v-show="condition"></custom-component> <p v-else>这可能也是一个组件</p> // 正确做法 <custom-component v-show="condition"></custom-component> <p v-show="!condition">这可能也是一个组件</p>
#解決vue頁面載入時出現{{message}}閃退
#方法一:v-cloak
v-cloak指令和css規則如[v-cloak]{display:none}一起用時,這個指令可以隱藏未編譯的Mustache標籤直到實例準備完畢。
v-cloak 指令可以像css選擇器一樣綁定一套css樣式然後這套css會一直生效到實例編譯結束。
eg: // <p> 不会显示,直到编译结束。 [v-cloak]{ display:none; } <p v-cloak> {{ message }} </p>
方法二:v-text
vue中我們會將封包在兩個大括號中,然後放到HTML裡,但在vue內部,所有的雙括號會被編譯成textNode的一個v-text指令。
而使用v-text的好處是永遠更好的效能,更重要的是可以避免FOUC (Flash of Uncompiled Content) ,也就是上面與遇到的問題。
eg: <span v-text="message"></span> <!-- same as --> <span>{{message}}</span>
補充:
vue 頁面載入進度條元件
頁面載入進度條最初我是在youtube上看到的,後面幾乎在各大網站上都能見到它的身影,可以讓用戶在加載頁面的時候不會對著完全空白的頁面發呆,提升用戶體驗
但從開發角度講,這種進度條在真實性上確實很難把握,因為在邏輯程式碼載入完成之前,我們都不能統計到進度,而邏輯程式碼本身的進度也無法統計。另外,我們不可能監控到所有資源的載入情況。
事實上,使用者並不是在乎你的頁面究竟加載了百分之幾,而真正關心的是離加載完還有多久,以及這個空白頁面是沒有加載完,還是加載完就是空白的。所以沒我們需要去「模擬」一個進度條,在後端數據返回前利用一個假的動畫效果模擬加載,在數據返回後讀完進度條並且隱藏。
// progress-bar.vue <template> <transition name="fade"> <p class="progress-bar" v-if="isShow"> </p> </transition> </template> <script type="text/babel"> export default { data() { return { isShow: true, // 是否显示进度条 val: 0, // 进度 } }, props: { /** * 每10毫秒自增幅度 */ step: { type: Number, default: 5, }, /** * 初始值 */ initVal: { type: Number, default: 0, }, /** * 到一定进度停止 */ stopVal: { type: Number, default: 80, }, /** * 进度条继续到成功 */ isOk: { type: Boolean, default: false, }, }, mounted() { // 初始化后加载进度,加载到百分之多少由stopVal决定 this.val = this.initVal let step = this.step let timer = setInterval(() => { this.val = this.val + step this.$el.style.width = this.val + '%' // 父组件数据加载完前进度条最多到stopVal的这个百分值 if (this.val >= this.stopVal) { clearInterval(timer) return } }, 10) }, watch: { /** * 监听组件props变化决定是否继续加载,一般在父组件数据加载完后改变此标志位 */ isOk() { let val = this.val let step = this.step let timer = setInterval(() => { val = val + step this.$el.style.width = val + '%' // 加载到百分百完成 if (val >= 100) { // 关闭定时器 clearInterval(timer) // 加载完成关闭进度条 this.isShow = false // 加载完成的回调 this.$emit('callback', 'load success') return } }, 10) }, }, } </script> <style lang="stylus" rel="stylesheet/stylus"> .progress-bar { position fixed top 0 height 6px width 0 background-color #999 } .fade { &-enter-active, &-leave-active { transition: all .3s } &-enter, &-leave-active { opacity: 0 } } </style>
我相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
推薦閱讀:
以上是vue中v-if與v-show使用和區別的詳細內容。更多資訊請關注PHP中文網其他相關文章!