(七)vue:v-cloak用法

一.指令说明

首先我们看下官方的解释:
在这里插入图片描述
文档中写的很清晰,下面我们会举例说明。

二.举例讲解

直接看下面的代码:

<div id="app">
        <h1>{{message}}</h1>
</div>
<script>
    var app = new Vue({
        el:'#app',
        data:{
            message:"hello world"
        }
    });
</script>

上面代码,渲染结果很清楚,浏览器会直接显示hello world:
在这里插入图片描述
让我们深入研究下浏览器解析的过程,首先浏览器先加载了div字段,然后在加载我们的脚本script。那么在脚本编译完成之前的一个短暂的时间内,页面上应该是 {{message}},只不过这个时间太短了,所以我们观察不到这一个现象,所以我们把代码稍作修改:

    <script>
        // var app = new Vue({
        //     el:'#app',
        //     data:{
        //         message:"hello world"
        //     }
        // });
        setTimeout(function(){
            new Vue({
            el:'#app',
            data:{
                message:"hello world"
            }
        })
        }, 2000);
    </script>

然后用浏览器打开,可以观察到首先显示 {{message}},2秒之后变成hello world:
在这里插入图片描述
所以为了避免这个现象,应该怎么处理,这个时候就需要我们的主角 v-cloak出场了,将html改为:

<h1 v-cloak>{{message}}</h1>

打开浏览器控制台,查看dom节点的变化,在vue编译完成之前,节点上有我们添加的v-cloak属性,等vue编译完成之后,v-cloak实例消失
在这里插入图片描述
在这里插入图片描述
我们可以利用这一个特点,为v-cloak添加一个style:

    <style>
        [v-cloak]{
            display: none;
        }
    </style>

大家可能已经知道最后结果了,因为我们为v-cloak添加了css,所以在vue实例编译完成之前 h1节点将不会显示,等vue实例编译完成 h1节点才会显示。所以我们不会再看到 {{message}}

参考原文地址

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值