内置指令
v-text
更新元素的文本内容。
-
期望的绑定值类型:
string
-
详细信息
v-text
通过设置元素的 textContent 属性来工作,因此它将覆盖元素中所有现有的内容。如果你需要更新textContent
的部分,应该使用 mustache interpolations 代替。 -
示例
-
参考 模板语法 - 文本插值
v-html
更新元素的 innerHTML 。
-
期望的绑定值类型:
string
-
详细信息
v-html
的内容直接作为普通 HTML 插入—— Vue 模板语法是不会被解析的。如果你发现自己正打算用
v-html
来编写模板,不如重新想想怎么使用组件来代替。
安全说明
在你的站点上动态渲染任意的 HTML 是非常危险的,因为它很容易导致 XSS 攻击 。请只对可信内容使用 HTML 插值, 绝不要 将用户提供的内容作为插值
在
单文件组件
,
scoped
样式将不会作用于
v-html
里的内容,因为 HTML 内容不会被 Vue 的模板编译器解析。如果你想让
v-html
的内容也支持 scoped CSS,你可以使用
CSS modules
或使用一个额外的全局
<style>
元素,手动设置类似 BEM 的作用域策略。
-
示例
v-show
基于表达式值的真假性,来改变元素的可见性。
-
期望的绑定值类型:
any
-
详细信息
v-show
通过设置内联样式的display
CSS 属性来工作,当元素可见时将使用初始display
值。当条件改变时,也会触发过渡效果。
v-if
基于表达式值的真假性,来条件性地渲染元素或者模板片段。
-
期望的绑定值类型:
any
-
详细信息
当
v-if
元素被触发,元素及其所包含的指令/组件都会销毁和重构。如果初始条件是假,那么其内部的内容根本都不会被渲染。可用于
<template>
表示仅包含文本或多个元素的条件块。当条件改变时会触发过渡效果。
当同时使用时,
v-if
比v-for
优先级更高。我们并不推荐在一元素上同时使用这两个指令 — 查看 列表渲染指南 详情。 -
参考 条件渲染 - v-if
v-else
表示
v-if
或
v-if
/
v-else-if
链式调用的“else 块”。
-
无需传入表达式
-
详细信息
-
限定:上一个兄弟元素必须有
v-if
或v-else-if
。 -
可用于
<template>
表示仅包含文本或多个元素的条件块。
-
-
示例
v-else-if
表示
v-if
的“else if 块”。可以进行链式调用。
-
期望的绑定值类型:
any
-
详细信息
-
限定:上一个兄弟元素必须有
v-if
或v-else-if
。 -
可用于
<template>
表示仅包含文本或多个元素的条件块。
-
-
示例
v-for
基于原始数据多次渲染元素或模板块。
-
期望的绑定值类型:
Array | Object | number | string | Iterable
-
详细信息
指令值必须使用特殊语法
alias in expression
为正在迭代的元素提供一个别名:或者,你也可以为索引指定别名 (如果用在对象,则是键值):
v-for
的默认方式是尝试就地更新元素而不移动它们。要强制其重新排序元素,你需要用特殊 attributekey
来提供一个排序提示:v-for
也可以用于 Iterable Protocol 的实现,包括原生Map
和Set
。 -
参考
v-on
给元素绑定事件监听器。
-
缩写:
@
-
期望的绑定值类型:
Function | Inline Statement | Object (不带参数)
-
参数:
event
(使用对象语法则为可选项) -
修饰符
-
.stop
- 调用event.stopPropagation()
。 -
.prevent
- 调用event.preventDefault()
。 -
.capture
- 在捕获模式添加事件监听器。 -
.self
- 只有事件从元素本身发出才触发处理函数。 -
.{keyAlias}
- 只在某些按键下触发处理函数。 -
.once
- 最多触发一次处理函数。 -
.left
- 只在鼠标左键事件触发处理函数。 -
.right
- 只在鼠标右键事件触发处理函数。 -
.middle
- 只在鼠标中键事件触发处理函数。 -
.passive
- 通过{ passive: true }
附加一个 DOM 事件。
-
-
详细信息
事件类型由参数来指定。表达式可以是一个方法名,一个内联声明,如果有修饰符则可省略。
当用于普通元素,只监听 原生 DOM 事件 。当用于自定义元素组件,则监听子组件触发的 自定义事件 。
当监听原生 DOM 事件时,方法接收原生事件作为唯一参数。如果使用内联声明,声明可以访问一个特殊的
$event
变量:v-on:click="handle('ok', $event)"
。v-on
还支持绑定不带参数的事件/监听器对的对象。请注意,当使用对象语法时,不支持任何修饰符。 -
示例
监听子组件的自定义事件 (当子组件的“my-event”事件被触发,处理函数将被调用):
-
参考
v-bind
动态的绑定一个或多个 attribute,也可以是组件的 prop。
-
缩写:
-
:
或者.
(当使用.prop
修饰符) - 值可以省略 (当 attribute 和绑定的值同名时) 3.4+
-
-
期望:
any (带参数) | Object (不带参数)
-
参数:
attrOrProp (可选的)
-
修饰符
-
.camel
- 将短横线命名的 attribute 转变为驼峰式命名。 -
.prop
- 强制绑定为 DOM property。 3.2+ -
.attr
- 强制绑定为 DOM attribute。 3.2+
-
-
用途
当用于绑定
class
或style
attribute,v-bind
支持额外的值类型如数组或对象。详见下方的指南链接。在处理绑定时,Vue 默认会利用
in
操作符来检查该元素上是否定义了和绑定的 key 同名的 DOM property。如果存在同名的 property,则 Vue 会将它作为 DOM property 赋值,而不是作为 attribute 设置。这个行为在大多数情况都符合期望的绑定值类型,但是你也可以显式用.prop
和.attr
修饰符来强制绑定方式。有时这是必要的,特别是在和 自定义元素 打交道时。当用于组件 props 绑定时,所绑定的 props 必须在子组件中已被正确声明。
当不带参数使用时,可以用于绑定一个包含了多个 attribute 名称-绑定值对的对象。
-
示例
.prop
修饰符也有专门的缩写,.
:当在 DOM 内模板使用
.camel
修饰符,可以驼峰化v-bind
attribute 的名称,例如 SVGviewBox
attribute:如果使用字符串模板或使用构建步骤预编译模板,则不需要
.camel
。 -
参考
v-model
在表单输入元素或组件上创建双向绑定。
-
期望的绑定值类型 :根据表单输入元素或组件输出的值而变化
-
仅限:
-
<input>
-
<select>
-
<textarea>
- components
-
-
修饰符
-
参考
v-slot
用于声明具名插槽或是期望接收 props 的作用域插槽。
-
缩写:
#
-
期望的绑定值类型 :能够合法在函数参数位置使用的 JavaScript 表达式。支持解构语法。绑定值是可选的——只有在给作用域插槽传递 props 才需要。
-
参数 :插槽名 (可选,默认是
default
) -
仅限:
-
<template>
- components (用于带有 prop 的单个默认插槽)
-
-
示例
-
参考
v-pre
跳过该元素及其所有子元素的编译。
-
无需传入
-
详细信息
元素内具有
v-pre
,所有 Vue 模板语法都会被保留并按原样渲染。最常见的用例就是显示原始双大括号标签及内容。 -
示例
v-once
仅渲染元素和组件一次,并跳过之后的更新。
-
无需传入
-
详细信息
在随后的重新渲染,元素/组件及其所有子项将被当作静态内容并跳过渲染。这可以用来优化更新时的性能。
从 3.2 起,你也可以搭配
v-memo
的无效条件来缓存部分模板。 -
参考
v-memo
-
期望的绑定值类型:
any[]
-
详细信息
缓存一个模板的子树。在元素和组件上都可以使用。为了实现缓存,该指令需要传入一个固定长度的依赖值数组进行比较。如果数组里的每个值都与最后一次的渲染相同,那么整个子树的更新将被跳过。举例来说:
当组件重新渲染,如果
valueA
和valueB
都保持不变,这个<div>
及其子项的所有更新都将被跳过。实际上,甚至虚拟 DOM 的 vnode 创建也将被跳过,因为缓存的子树副本可以被重新使用。正确指定缓存数组很重要,否则应该生效的更新可能被跳过。
v-memo
传入空依赖数组 (v-memo="[]"
) 将与v-once
效果相同。与
v-for
一起使用v-memo
仅用于性能至上场景中的微小优化,应该很少需要。最常见的情况可能是有助于渲染海量v-for
列表 (长度超过 1000 的情况):当组件的
selected
状态改变,默认会重新创建大量的 vnode,尽管绝大部分都跟之前是一模一样的。v-memo
用在这里本质上是在说“只有当该项的被选中状态改变时才需要更新”。这使得每个选中状态没有变的项能完全重用之前的 vnode 并跳过差异比较。注意这里 memo 依赖数组中并不需要包含item.id
,因为 Vue 也会根据 item 的:key
进行判断。警告
当搭配
v-for
使用v-memo
,确保两者都绑定在同一个元素上。v-memo
不能用在v-for
内部。v-memo
也能被用于在一些默认优化失败的边际情况下,手动避免子组件出现不需要的更新。但是一样的,开发者需要负责指定正确的依赖数组以免跳过必要的更新。 -
参考
v-cloak
用于隐藏尚未完成编译的 DOM 模板。
-
无需传入
-
详细信息
该指令只在没有构建步骤的环境下需要使用。
当使用直接在 DOM 中书写的模板时,可能会出现一种叫做“未编译模板闪现”的情况:用户可能先看到的是还没编译完成的双大括号标签,直到挂载的组件将它们替换为实际渲染的内容。
v-cloak
会保留在所绑定的元素上,直到相关组件实例被挂载后才移除。配合像[v-cloak] { display: none }
这样的 CSS 规则,它可以在组件编译完毕前隐藏原始模板。 -
示例