第五节:Vue指令:基本认识使用/v-text/v-html/v-cloak/v-once/v-pre

认识vue指令

vue的指令directive只是dom的行间属性,vue给这类属性赋予了一定的意义, 来实现特殊的功能,所有的指令都以v-开头

指令的职责是,当表达式的值改变时,将其产生的连带影响,响应式地作用于 DOM。

那么接下来我们好好看看Vue给我们提供了那些指令


1. v-text 指令

1.1 v-text指令的基本用法
  1. v-text 能展示对应data中数据内容,也能在数据基础上做运算
  2. v-text 会把标签中的内容替换,类似于innerText
<div id="app">
    <!-- 将data 中的数据渲染在页面上-->
    <div v-text='msg'></div>

    <!-- v-text可以对data数据内容做简单的运算-->
    <div v-text='msg + "world"'></div>

</div>

<script>
    var vm = new Vue({
        el: '#app',
        data: {
            msg:"hello"
        }
    })
</script>

注意指令(属性)的值虽然加了引号, 但是引号内不是字符串,而是表达式, msg是表达式中的变量,如果需要在表达式中使用字符串,需要再次添加引号, 但是要注意引号的冲突

所以第二个div的v-text指令是变量msg和字符串world做了一个简单的字符串拼接

显示结果:

v-text.png


1.2 v-text指令覆盖标签嵌套内容

我们有讲到v-text指令有点类似于innerText,所以在使用v-text指令的标签内不要添加任何内容, 因为会被覆盖,
示例如下:

<div id="app">
    <!-- 使用v-text标签中不能添加内容,会被覆盖 -->
    <!-- 使用v-text指令标签中添加普通字符 -->
    <div v-text='msg'>
        你好! 中国
    </div>

    <!-- 使用v-text指令标签中添加标签 -->
    <div v-text='msg +" " + "world"'>
        <h2>我就是一个标题</h2>
    </div>

</div>

<script>
    var vm = new Vue({
        el: '#app',
        data: {
            msg:"hello"
        }
    })
</script>

显示结果

v-text2.png

通过示例,发现使用v-text标签内的数据全被覆盖了

v-text可以取代{{}} 它也有不好的地方就是会替换标签内的所有的内容,无论普通字符还是标签

Mustache语法只会在指定的地方编译内容


2. v-cloak 指令

{{}}这种插值符号在页面刷新的时候,会出现在页面上, {{}}插值表达式会闪烁,

v-cloak 解决闪烁(块)问题

2.1 v-cloak 指令的使用

第一步要给元素添加v-cloak

<div v-cloak></div>

第二步: 手动的给这个元素添加display:none;

[v-cloak]{
    display:none;
}

了解一下,后期用不到


3.v-html 指令

双大括号会将数据解释为普通文本,而非 HTML 代码。为了输出真正的 HTML,你需要使用 v-html 指令:

3.1 v-html指令的基本使用

把html字符串当成html渲染.类似于innerHTML

<div id="app">
    <!-- v-text无法解析数据中的标签 -->
    <div v-text="msg"></div>

    <!-- v-html可以解析数据中的标签 -->
    <div v-html="msg"></div>

</div>

<script>
    var vm = new Vue({
        el: '#app',
        data: {
            msg:"<h2>hello wrold</h2>"
        }
    })
</script>

显示结果

v-html.png

通过示例结果, 我们发现红色使用v-text指令的div并没有解析出数据中的h2标签

蓝色使用v-html指令的div,将数据中的h2解析成了标签

但是一定要注意,v-html指令一定要慎用, 可能会攻击,如果在数据里添加一个script标签也能识别,那么script里面就可能会添加攻击你的脚本.

所以如果要使用v-html指令,一定要是可信任的.不信任的会有问题


3.2 总结三种将数据渲染的页面的方法
  1. 虽然上面三种方法都可以将数据渲染到页面上,但是工作中我最常用的是{{}}
  2. {{}} 最被常用但是在加载的时候会出现闪烁问题(指令篇章v-cloak会讲解解决方法),无法将html格式数据渲染,只能当字符串展示
  3. v-text 虽然没有数据加载闪烁问题,但是会将标签中间的数据覆盖,也不能渲染html格式数据。
  4. v-html 谨慎使用会出现xss攻击的风险


4.v-once指令,

平时我们使用Mustache语法,包括v-text,v-html指令渲染的页面都是具有响应式的, 当数据发生变化, 视图也会跟着改变

v-once属性不用设置值,使用{{}}插值符号插值,v-once值得是只会初始化插值一次;当数据发生变化是,页面视图不会发生改变

<div id="app">
    <!-- 使用v-once指令 -->
    <div v-once>{{msg}}</div>

    <!-- 未使用v-once指令 -->
    <div>{{msg}}</div>
</div>

<script>
    const vm = new Vue({
        el: "#app",
        data: {
            msg: 'hello wrold'
        }
    })

    //  就是3秒以后  数据发生了变化,页面视图也不会有任何改变,
    setTimeout(() => {
        vm.msg = "你好 "
    }, 3000)
</script>

示例在开始时,两个div显示的都是hello wrold,

但是3秒钟以后显示的结果如下

v-once.png

我们会发现未使用v-once指令的div在数据发生变化以后, 页面显示的结果也跟随数据发生了变化,但是使用了v-once指令的div只会在初始化的时候显示,显示之后就不会再随着页面的变化而变化了


5. v-pre指令

不编译指令,这个指令不需要表达式

用法

跳过这个元素和它的子元素的编译过程。可以用来显示原始 Mustache 标签。跳过大量没有指令的节点会加快编译。

示例:

正常编译示例

<div id="app">
   <span>{{ msg }}</span>
</div>

<script>
   var vm = new Vue({
       el: '#app',
       data: {
           msg:"hello world"
       }
   })
</script>

显示结果:

非v-pre.png

使用v-pre指令

<div id="app">
    <!-- v-pre指令不需要值 -->
    <span v-pre>{{ msg }}</span>
</div>

<script>
    var vm = new Vue({
        el: '#app',
        data: {
            msg:"hello world"
        }
    })
</script>

显示结果:

v-pre指令.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,172评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,346评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,788评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,299评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,409评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,467评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,476评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,262评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,699评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,994评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,167评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,499评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,149评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,387评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,028评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,055评论 2 352