02 v-cloak v-text v-html

v-cloak

<html>
  <head>
      <meta charset="utf-8"></meta>
      <title>v-cloak</title>
      <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  </head>
  <body>
      <div id="app">
          {{msg}}
      </div>
      <script>
        var vm = new Vue({
            el: "#app", 
            data:{
                msg:"123"   
            }
        })
        </script>
  </body>
</html>

在网速正常的时候,上述代码会迅速出现123这个值,但也能看到由{{msg}}123转变的过程,在网速缓慢的时候更为明显。

解决插值表达式的上述问题就需要用到v-cloak属性。

<style>
     [v-cloak]{
         display: none;
     }
</style>
<div id="app">
     <p v-cloak>{{msg}}</p>
</div>

将上述代码添加到html文件即可解决闪烁问题。

v-text

v-text可以获取Vue对象中data的内容。在上述例子的基础上,添加:

<h4 v-text="msg"></h4>

即可获取到msg的值。

那么它与插值表达式{{}}有什么区别和联系呢?

  • v-text无闪烁问题

  • 具有v-text属性的dom元素中的内容不会显示到页面上,如:

     <h4 v-text="msg">----</h4>
    

    其中的----不会出现在页面上,会被覆盖,但插值表达式的前后可以添加其他的值,不会覆盖

  • v-text和插值表达式不能解析html语句

v-html

上文说到v-text和插值表达式无法解析html语句,所以v-html出现了。

<p v-html="msg2"></p>
var vm = new Vue({
            el: "#app", 
            data:{
                msg:"123",
                msg2:"<h1>ss</h1>"
            }
})

这段代码即可将msg2解析为html代码进行输出。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值