![Vue.js从入门到项目实践(超值版)](https://wfqqreader-1252317822.image.myqcloud.com/cover/987/44509987/b_44509987.jpg)
3.1.1 指令
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P41_3295.jpg?sign=1739678731-n6dB8a38i0Kuaf1UdxI4NyH1MFKFoITd-0-3f585b138770215095ae95efdfe70385)
指令(directives)是Vue中最常用的功能,以带有v-前缀的特殊属性形式呈现,主要负责当表达式的值改变时,将其产生的连带影响响应式地作用于DOM。
1.v-bind
v-bind:响应并更新DOM特性,例如v-bind:href、v-bind:class、v-bind:title等。
主要用法:绑定属性、动态更新HTML元素上的属性。
代码如下:
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P42_52959.jpg?sign=1739678731-5p6pU0Ob4cWi3mz9bxRsvAMA43w9dwT9-0-cb961cb210677b3d3ea06cd87edfcd95)
运行效果如图3-1所示。
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P42_3408.jpg?sign=1739678731-Bp6QPNY28N3rhzy1tpYN3CQZhRL25H3r-0-a7b85088799283d62947d4a06b13f04f)
图3-1 v-bind运行效果
2.v-model
v-model:数据双向绑定,用于表单输入,例如<input v-model="message">。
主要用法:用在input、select、text、checkbox、radio等表单控件或者组件上创建双向绑定。它会根据控件类型自动选取正确的方法来更新元素,主要负责监听用户的输入事件以更新数据,并处理一些极端的例子。
代码如下:
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P43_52961.jpg?sign=1739678731-TpH9VQq2GclRPpJlztVDhouhQqAnvd2J-0-d441a405a7af0e6b38dd3b8b93f660a5)
运行效果如图3-2所示。
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P43_3565.jpg?sign=1739678731-LE6fzvF5nyxbFuXU8PdHmntlr14sll9Z-0-fb0b12d63a1452005f904f68ce8b496d)
图3-2 v-model运行效果图
3.v-for
v-for:循环指令。例如:
<li v-for="(item,index) in todos"></li>
主要用法:基于源数据多次渲染元素或模块。此指令的值必须使用特定语法,为当前遍历的元素提供别名。
代码如下:
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P44_52966.jpg?sign=1739678731-kenCvOEhvWkIlPbxCZVu1Gwmzhp01lnP-0-07b235de37482f4c742f52cf4d9001b6)
运行效果如图3-3所示。
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P44_3751.jpg?sign=1739678731-AFWTL9VnMvrzJRvkFxJeBeXNpnUgLBTu-0-19310cd2ba6929a3c89ff1649b56cf08)
图3-3 v-for运行效果图
提示:上述代码中的<li v-for='value in arr'>,如果其值为'value in arr',则在控制台显示data中arr的内容;如果其值为'value in json',则显示data中json的内容。
4.v-on
v-on:用于监听DOM事件,例如v-on:click、v-on:keyup等。
主要用法:绑定事件监听器。事件类型由参数指定,表达式可以是一个方法的名称或一个内联语句,如果没有修饰符也可以省略。V-on用在普通元素上时,只能监听原生DOM事件;用在自定义元素组件上时,能监听子组件触发的自定义事件。在监听原生DOM事件时,方法以事件为唯一的参数。如果使用内联语句,语句可以访问一个$event**属性:**v-on:click="handle('ok', $event)"。
代码如下:
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P45_52968.jpg?sign=1739678731-cE4UxGrQTnfupRNNgczodYrTiGCVPTfG-0-7ce41dd3cd8cba98d4e4fd5d0673ffcf)
运行效果如图3-4所示。
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P45_3929.jpg?sign=1739678731-3ejvVZmm3LbDFt6JTMMam2PkwGTjt8jP-0-a560d6d4291083e6ff99f0dffbd2e549)
图3-4 v-on运行效果图
5.v-html
v-html:更新元素的innerHTML。
提示:按普通HTML插入“-”,不会作为Vue模板进行编译。如果试图使用v-html组合模板,可以重新考虑是否通过使用组件来替代。在网站上动态渲染任意HTML是非常危险的,容易导致XSS攻击。建议只在可信内容上使用v-html,不在用户提交的内容上使用。
代码如下:
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P46_52971.jpg?sign=1739678731-8YXtq86tKNaax9zpdWTdp0oqjVxGFsco-0-01c06be00eb8cb5388fcf5c272aafb78)
运行效果如图3-5所示。
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P46_4053.jpg?sign=1739678731-gLNNrxFCGvzIA4HHrNx1l0xkrcmOO8a9-0-d5cbf6562b022d40c62e8db440d416f2)
图3-5 v-html运行效果图
6.v-text
v-text:更新元素的textContent,例如<span v-text="msg"></span>等同于<span>{{msg}}</span>。
主要用法:更新元素的textContent。如果要更新部分的textContent,需要使用{{mustache}}插值。
提示:使用<span v-text="msg"></span>和<span>{{msg}}</span>两种写法都可以。
代码如下:
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P46_52972.jpg?sign=1739678731-9sqzZyskHyeB1Y05bTHsyMPFzFILeJ5t-0-5228f6ccc94623df0fbbce11e381ac5a)
运行效果如图3-6所示。
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P47_4342.jpg?sign=1739678731-ujwgNkCSY63llAvpnAINdc4CYPsQznV1-0-0c15d6f458d118126c002c270f3dd946)
图3-6 v-text运行效果图
7.v-cloak
v-cloak:不需要表达式,这个指令保持在元素上,直到关联实例结束编译。
主要用法:当Cloak和CSS规则(如[v-cloak] {display: none})一起用时,这个指令可以隐藏未编译的<mustache>标签直到实例准备完毕,否则在渲染页面时,有可能用户会先看到<mustache>标签,然后看到编译后的数据。
代码如下:
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P47_52974.jpg?sign=1739678731-Z6M5ojDSkmmxSc8gAyqlo5v2bfGDyEHE-0-e37e980da735952690f88549648b5434)
运行效果如图3-7所示。
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P48_4525.jpg?sign=1739678731-RTHQTsOWyOKJZBxRTb49Efhy91Yn9CLt-0-b73933ba383f99ecbbc1d86f1a7e6c1e)
图3-7 v-cloak运行效果图
8.v-pre
v-pre:不需要表达式,用于跳过元素及子元素的编译过程,以此来加快整个项目的编译速度。例如:
<span v-pre>{{ this will not be compiled }}</span>
主要用法:跳过元素和它的子元素的编译过程。此外,它可以用来显示原始<mustache>标签。
代码如下:
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P48_52976.jpg?sign=1739678731-tZwYnEUG3ffOU6ZzulSeQ8kLmOfXDIi5-0-d54fa78fd193832c52a5c48b8a191128)
运行效果如图3-8所示。
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P49_4697.jpg?sign=1739678731-01tbKfLPmzAe1Wp9eb4FTa2y5R1GX6Ko-0-5a5c4da12e6c0d369b38cabe1fb914e8)
图3-8 v-pre运行效果图
9.v-once
v-once:不需要表达式,只渲染元素或组件一次。以后渲染时,组件/元素及下面的子元素都当成静态页面不再被渲染,这可以用于优化更新性能。
代码如下:
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P49_52977.jpg?sign=1739678731-n2GGlbKJWfMv9HYv1YuBGQXvW93Zaw1Y-0-4f7e8f498ddc6bf5570ec53f60a0e1bd)
运行效果如图3-9所示。
![](https://epubservercos.yuewen.com/CC45E5/23721548909464406/epubprivate/OEBPS/Images/Figure-P49_4875.jpg?sign=1739678731-eaGsTehmAgZgvC2yYDJ0hmj8ugyLnnNT-0-90d4d6aadbaa6305e8abb22aa34bc952)
图3-9 v-once运行效果图