vue开发手机页面闪烁_Vue页面加载闪烁问题的解决方法_婳祎_前端开发者
v-if 和 v-show 的區(qū)別
v-if只會在滿足條件時才會編譯,而v-show不管是否滿足條件始終會編譯,v-show的顯示與隱藏只是簡單的切換
也就是說,在使用v-if時,若值為false,那么頁面將不會有這個
使用場景
一般來說,v-if 有更高的切換消耗而 v-show 有更高的初始渲染消耗。因此,如果需要頻繁切換 v-show 較好,如果在運(yùn)行時條件不大可能改變 v-if 較好。
另外
1.v-if 指令可以應(yīng)用于template包裝元素上,而v-show不支持template
2.將v-show應(yīng)用在組件上時,因為指令的優(yōu)先級 v-else 會出現(xiàn)問題,解決辦法就是用另一個 v-show 替換 v-else
// 錯誤
這可能也是一個組件
// 正確做法
這可能也是一個組件
解決
方法一:v-cloak
v-cloak指令和
eg:
//
不會顯示,直到編譯結(jié)束。[v-cloak]{
display:none;
}
{{ message }}
方法二:v-text
而使用v-text的好處就是永遠(yuǎn)更好的性能,更重要的是可以避免FOUC (Flash of Uncompiled Content) ,也就是上面與遇到的問題。
eg:
{{message}}
補(bǔ)充:
頁面加載進(jìn)度條最初我是在youtube上看到的,后面幾乎在各大網(wǎng)站上都能見到它的身影,可以讓用戶在加載頁面的時候不會對著完全空白的頁面發(fā)呆,提升用戶體驗
但是從開發(fā)角度講,這種進(jìn)度條在真實性上確實很難把握,因為在邏輯代碼加載完成之前,我們都不能統(tǒng)計到進(jìn)度,而邏輯代碼自身的進(jìn)度也無法統(tǒng)計。另外,我們不可能監(jiān)控到所有
事實上,用戶并不是在乎你的頁面究竟加載了百分之幾,而真正關(guān)心的是離加載完還有多久,以及這個空白頁面是沒有加載完,還是加載完就是空白的。所以沒我們需要去“模擬”一個進(jìn)度條,在后端數(shù)據(jù)返回前利用一個假的動畫效果模擬加載,在數(shù)據(jù)返回后讀完進(jìn)度條并且隱藏。
// progress-bar.vue
export default {
data() {
return {
isShow: true, // 是否顯示進(jìn)度條
val: 0, // 進(jìn)度
}
},
props: {
/**
* 每10毫秒自增幅度
*/
step: {
type: Number,
default: 5,
},
/**
* 初始值
*/
initVal: {
type: Number,
default: 0,
},
/**
* 到一定進(jìn)度停止
*/
stopVal: {
type: Number,
default: 80,
},
/**
* 進(jìn)度條繼續(xù)到成功
*/
isOk: {
type: Boolean,
default: false,
},
},
mounted() {
// 初始化后加載進(jìn)度,加載到百分之多少由stopVal決定
this.val = this.initVal
let step = this.step
let timer = setInterval(() => {
this.val = this.val + step
this.$el.style.width = this.val + '%'
// 父組件數(shù)據(jù)加載完前進(jìn)度條最多到stopVal的這個百分值
if (this.val >= this.stopVal) {
clearInterval(timer)
return
}
}, 10)
},
watch: {
/**
* 監(jiān)聽組件props變化決定是否繼續(xù)加載,一般在父組件數(shù)據(jù)加載完后改變此標(biāo)志位
*/
isOk() {
let val = this.val
let step = this.step
let timer = setInterval(() => {
val = val + step
this.$el.style.width = val + '%'
// 加載到百分百完成
if (val >= 100) {
// 關(guān)閉定時器
clearInterval(timer)
// 加載完成關(guān)閉進(jìn)度條
this.isShow = false
// 加載完成的回調(diào)
this.$emit('callback', 'load success')
return
}
}, 10)
},
},
}
.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
}
}
總結(jié)
以上所述是小編給大家介紹的vue頁面加載閃爍問題的解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對前端開發(fā)者網(wǎng)站的支持!
總結(jié)
以上是生活随笔為你收集整理的vue开发手机页面闪烁_Vue页面加载闪烁问题的解决方法_婳祎_前端开发者的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python bottle支持https
- 下一篇: java 反射的弊端_java反射机制的