Vue学习笔记(三、v-cloak、v-text、v-html指令)

一、 v-cloak

v-cloak 是 Vue.js 提供的一个特殊指令,用于在 Vue 实例准备完毕并开始进行 DOM 编译之前隐藏未编译的模板。它通常用于防止页面闪烁或者展示未编译的 Vue 模板语法。

你可以简单地在 HTML 元素上添加 v-cloak 指令,然后在确保 Vue 实例已经编译完成之前,通过 CSS 隐藏这些元素。当 Vue 实例编译完成后,会自动移除 v-cloak 属性,从而显示内容。

在下面的代码中 ,我们把Vue.js的引入放到了p元素之后,这样p元素在vue.js引入之前会渲染为"{{msg}}",等vue.js引入之后才会渲染为"Vue的基础代码学习",我们称之为一种"闪烁"现象,如果感受不到这个问题,可以把浏览器调整为慢速3G感受一下。

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>VueBaseCode</title>
</head>

<body>

    <div id="app">
        <p>{{msg}}</p>
    </div>
    
    <script src="./lib/vue.js"></script>

    <script>
        var vm = new Vue({
            el: '#app',
            data: {
                msg: 'Vue的基础代码学习'
            }
        });
    </script>
</body>

</html>

为了解决这个问题,我们先是在style中定义了v-cloak指令:

html 复制代码
<style>
    [v-cloak]{
        display: none;
    }
</style>

然后在p元素中使用了这个指令:

html 复制代码
 <p  v-cloak>{{msg}}</p>

完整代码如下:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>VueBaseCode</title>
</head>

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

<body>

    <div id="app">
        <p  v-cloak>{{msg}}</p>
    </div>
    
    <script src="./lib/vue.js"></script>

    <script>
        var vm = new Vue({
            el: '#app',
            data: {
                msg: 'Vue的基础代码学习'
            }
        });
    </script>
</body>

</html>

这样再vue.js加载完成之间,p元素会处于隐藏状态。

二、v-text

先看代码:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>VueBaseCode</title>
</head>

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

<body>

    <div id="app">
        <p  v-cloak>{{msg}}++{{msg}}</p>
        <h4  v-text="msg"></h4>
    </div>
    
    <script src="./lib/vue.js"></script>

    <script>
        var vm = new Vue({
            el: '#app',
            data: {
                msg: 'Vue的基础代码学习'
            }
        });
    </script>
</body>

</html>

在上面代码中h4中使用了v-text指令,其值为"msg",对应vm对象中data中的msg,同时h4中文本为空,这种情况下,h4元素在vue.js加载完成的情况下并不显示任何内容,直到vue.js加载完成之后,通过v-text="msg"指令获得了msg的值才被渲染出来,所以不存在闪烁问题。

但是p中包含的内容可以反复引用msg变量,同时可以添加其他内容,这也是v-text无法实现的,同时使用v-text时,当vue.js引入之后,h4之内的原始文本(假如有原始文本的话)会被msg的值替换掉。

三、v-html

参考代码如下:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>VueBaseCode</title>
</head>

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

<body>

    <div id="app">
        <p  v-cloak>{{msg}}++{{msg}}</p>
        <h4  v-text="msg"></h4>
        
        <p>{{msg2}}</p>
        <p v-text="msg2"></p>
        <p v-html="msg2"></p>
    </div>
    
    <script src="./lib/vue.js"></script>

    <script>
        var vm = new Vue({
            el: '#app',
            data: {
                msg: 'Vue的基础代码学习',
                msg2:"<h1>这是一个大标题</h1>"
            }
        });
    </script>
</body>

</html>

在上面的代码中只有

html 复制代码
 <p v-html="msg2"></p>

这一行能够把msg2的变量值当作html元素解析,其前面两种都是作为字符串直接输出的。

相关推荐
有梦想的程序星空17 小时前
【环境配置】使用 Vue CLI 构建 Vue 项目脚手架完整指南
前端·javascript·vue.js
杨先生哦18 小时前
【2026 热端攻防系列 2/12】DOM 型 XSS 深度实战:AI 多态变形免杀 + 全维度防御
前端·人工智能·笔记·安全·web安全·xss
俏皮小混子18 小时前
山东大学软件学院项目实训-创新实训-计科智伴(六)——个人博客(后端运行后真实调整)
人工智能·笔记·学习·ui
问心无愧051318 小时前
ctf show web入门115
android·前端·笔记
zhangrelay18 小时前
ROS2 Lyrical 入门+进阶+精通+……
linux·笔记·学习·机器人·课程设计
.千余18 小时前
【C++】C++ map 与 multimap 完全指南:键值对容器详解
开发语言·c++·笔记·学习·其他
小满Autumn1 天前
log4net 日志框架 — 从配置到实战速查手册
笔记·c#·.net·wpf·上位机·log4net
岁月宁静1 天前
RAG 文档摄入全链路,从原理到生产落地
vue.js·人工智能·python
袁小皮皮不皮1 天前
1.HCIP BFD 学习笔记(优化版)
服务器·网络·笔记·网络协议·学习·智能路由器·ip
#麻辣小龙虾#1 天前
基于vue3.0开发一款【固废与废气运维管理系统】(支持源码)
前端·vue.js·vue3