6、插值表达式和v-text指令

插值表达式和v-text都是显示数据的,但是插值表达式有个问题,如果频繁刷新页面或者网速特别慢的时候,页面会先显示{{msg}} 然后才会显示它指代的hello vue

vue中有个指令可以解决这个问题  v-cloak ,vue在页面传递数据时,如果插值表达式先开始没得到值,那么v-cloak会执行css样式display:none 不显示,待得到数据后移除这个样式。

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


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

并且css中添加

[v-cloak]{
    display:none
}

但有时候会不起作用,可能是两个原因:

1.v-cloak的display被层级更高的覆盖掉了,所以要提高层级

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

2.样式放在@import引入的css文件中

v-cloak放在@import引入的css文件中是不起作用的,可以放在link引入的css中或者写在内联样式中

 

v-text不会出现插值表达式出现的问题,那么为什么还存在插值表达式,而不全部用v-text呢?

因为插值表达式可以把vue传递过来的数据和用户自己定义的数据结合起来用,而v-text只能显示vue传递过来的数据,会替换掉节点里面已经有的数据。

<div id="app" v-cloak>
<p>这是从vue对象里获取的数据{{msg}}</p>
<p v-text="msg">这是从vue对象里获取的数据</p>
</div>

 

参考:vue -- v-cloak解决刷新或者加载出现闪烁(显示变量)

参考:Vue学习之路第三篇:插值表达式和v-text的区别

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值