vue v-cloak 解决页面加载时闪烁出现vue标签或者指令的问题

前沿

在项目在开发中,经常会遇到当数据加载时vue的一些标签就会闪现,然后等数据加载完后消失,这时候就需要用到官网中提到的v-cloak来解决。
首先说一下经常遇到的情况。
step1,加载时遇到{{value.name}}闪烁,是因为你在渲染时是这么写的

{{value.name}}

step2,加载时遇到一个空的盒子里边什么也没有,是因为你在渲染时是这么写的

解决办法
那么,v-cloak要放在什么位置呢,是不是每个需要渲染数据的标签都要添加这个指令,经过试验发现,v-cloak并不需要添加到每个标签,只要在el挂载的标签上添加就可以,这是最简单有效的办法

<div class="#app" v-cloak>
    <p>{{value.name}}</p>
</div>

然后,在css里面要添加

[v-cloak] {
    display: none;
}

这样就可以防止页面闪烁了。
但是有的时候会不起作用,可能的原因有二:
一,v-cloak的display属性被层级更高的给覆盖掉了,所以要提高层级

[v-cloak] {
    display: none !important;
}

二,样式放在了@import引入的css文件中(传统的开发方式)
v-cloak的这个样式放在@import 引入的css文件中不起作用,可以放在link引入的css文件里或者内联样式中

作者:愿醒静卧忘尘谷
链接:https://www.jianshu.com/p/0800f6bb52c8
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值