Vue3.0指令文档

本文章旨在让Vue初学者先了解Vue中的一些基本指令的用法!参考官网内置指令 | Vue.js

1、v-text:通过设置元素的textContent属性来更新元素的文本内容,期望绑定值的类型为string。

同mustache(也就是双括号)语法!

<span v-text="msg"></span>
<!-- 等同于 -->
<span>{{ msg }}</span>

2、v-html:更新元素的innerHTML。

注意:v-html 的内容直接作为普通 HTML 插入—— Vue 模板语法是不会被解析的。如果你发现自己正打算用 v-html 来编写模板,不如重新想想怎么使用组件来代替。

<div v-html="html"></div>

3、v-show:基于表达式的真假,改变元素是否可见。通过内联样式display CSS属性来工作。

4、v-if:基于表达式的真假,有条件性地渲染元素。当v-if元素被触发,元素及其所包含的指令或组件都会被销毁和重构。

注意:v-if 比v-for优先级更高。不推荐在同一元素上都使用这两指令。

4、v-else:表示 v-if 或 v-if / v-else-if 链式调用的“else 块”。

注意:限定上一个兄弟元素必须有 v-if 或 v-else-if

<div v-if="Math.random() > 0.5">
  Now you see me
</div>
<div v-else>
  Now you don't
</div>

5、v-else-if:表示 v-if 的“else if 块”。可以进行链式调用。也限定上一个兄弟元素必须有 v-if 或 v-else-if

<div v-if="type === 'A'">
  A
</div>
<div v-else-if="type === 'B'">
  B
</div>
<div v-else-if="type === 'C'">
  C
</div>
<div v-else>
  Not A/B/C
</div>

6、v-for:基于原始数据多次渲染元素或模板块。多绑定值类型为:Array、Object或number

<div v-for="(item, index) in items"></div>
<div v-for="(value, key) in object"></div>
<div v-for="(value, name, index) in object"></div>

注意:v-for 的默认方式是尝试就地更新元素而不移动它们。要强制其重新排序元素,你需要用特殊 attribute key 来提供一个排序提示

<div v-for="item in items" :key="item.id">
  {{ item.text }}
</div>

7、v-on:给元素绑定事件监听器。可缩写为@

修饰符

.stop - 调用 event.stopPropagation()

.prevent - 调用 event.preventDefault()

.capture - 在捕获模式添加事件监听器。

.self - 只有事件从元素本身发出才触发处理函数。

.{keyAlias} - 只在某些按键下触发处理函数。例如:@keyup.enter="doThis"

.once - 最多触发一次处理函数。

.left - 只在鼠标左键事件触发处理函数。

.right - 只在鼠标右键事件触发处理函数。

.middle - 只在鼠标中键事件触发处理函数。

.passive - 通过 { passive: true } 附加一个 DOM 事件。

<!-- 方法处理函数 -->
<button v-on:click="doThis"></button>

<!-- 动态事件 -->
<button v-on:[event]="doThis"></button>

<!-- 内联声明 -->
<button v-on:click="doThat('hello', $event)"></button>

<!-- 缩写 -->
<button @click="doThis"></button>

<!-- 使用缩写的动态事件 -->
<button @[event]="doThis"></button>

<!-- 停止传播 -->
<button @click.stop="doThis"></button>

<!-- 阻止默认事件 -->
<button @click.prevent="doThis"></button>

<!-- 不带表达式地阻止默认事件 -->
<form @submit.prevent></form>

<!-- 链式调用修饰符 -->
<button @click.stop.prevent="doThis"></button>

<!-- 按键用于 keyAlias 修饰符-->
<input @keyup.enter="onEnter" />

<!-- 点击事件将最多触发一次 -->
<button v-on:click.once="doThis"></button>

<!-- 对象语法 -->
<button v-on="{ mousedown: doThis, mouseup: doThat }"></button>

8、v-bind:动态绑定一个或多个attribute,也可以是组件的prop。可缩写为:或者.(当使用prop修饰符),当attribute和绑定的值同时名,值可以省略。

修饰符

.camel - 将短横线命名的 attribute 转变为驼峰式命名。

.prop - 强制绑定为 DOM property。(3.2+)

.attr - 强制绑定为 DOM attribute。(3.2+)

<!-- 绑定 attribute -->
<img v-bind:src="imageSrc" />

<!-- 动态 attribute 名 -->
<button v-bind:[key]="value"></button>

<!-- 缩写 -->
<img :src="imageSrc" />

<!-- 缩写形式的动态 attribute 名 (3.4+),扩展为 :src="src" -->
<img :src />

<!-- 动态 attribute 名的缩写 -->
<button :[key]="value"></button>

<!-- 内联字符串拼接 -->
<img :src="'/path/to/images/' + fileName" />

<!-- class 绑定 -->
<div :class="{ red: isRed }"></div>
<div :class="[classA, classB]"></div>
<div :class="[classA, { classB: isB, classC: isC }]"></div>

<!-- style 绑定 -->
<div :style="{ fontSize: size + 'px' }"></div>
<div :style="[styleObjectA, styleObjectB]"></div>

<!-- 绑定对象形式的 attribute -->
<div v-bind="{ id: someProp, 'other-attr': otherProp }"></div>

<!-- prop 绑定。“prop” 必须在子组件中已声明。 -->
<MyComponent :prop="someThing" />

<!-- 传递子父组件共有的 prop -->
<MyComponent v-bind="$props" />

<!-- XLink -->
<svg><a :xlink:special="foo"></a></svg>

9、v-model:在表单输入元素或组件上创建双向绑定。

v-model同时解决了手动绑定值和更改事件监听器两步操作。

文本类型的 <input> 和 <textarea> 元素会绑定 value property 并侦听 input 事件;

<input type="checkbox"> 和 <input type="radio"> 会绑定 checked property 并侦听 change 事件;

<select> 会绑定 value property 并侦听 change 事件。

<input v-model="text">
<!-- 等同于 -->
<input
  :value="text"
  @input="event => text = event.target.value">

仅限于用在以下元素:

<input>

<select>

<textarea>

components

修饰符

.lazy - 监听 change 事件而不是 input

<!-- 在 "change" 事件后同步更新而不是 "input" -->
<input v-model.lazy="msg" />

.number - 将输入的合法字符串转为数字

<input v-model.number="age" />

.trim - 移除输入内容两端空格

10、v-solt:用于声名具名插槽或是期望接收props的作用域插槽。可缩写为#

  • 期望的绑定值类型:能够合法在函数参数位置使用的 JavaScript 表达式。支持解构语法。绑定值是可选的——只有在给作用域插槽传递 props 才需要。

  • 参数:插槽名 (可选,默认是 default)

  • 仅限:

    • <template>
    • components (用于带有 prop 的单个默认插槽)

一般插槽,指只有插槽的出口及内容,无其他信息,用法如下:

<!--封装组件的代码:-->
<template>
  <el-button type="primary">
    <slot>
      <!-- 默认内容 -->
      这是一个按钮
    </slot>
  </el-button>
</template>


<!--应用组件的代码:-->
<template>
  <my-button>
   <!--指定内容-->
   提交
  </my-button>
</template>
 
<script setup>
import myButton from "./components/myButton.vue";
</script>

具名插槽,就 有名字的插槽。有时在一个组件中包含多个插槽出口是很有用的,<slot> 元素可以有一个特殊的 attribute name,用来给各个插槽分配唯一的 ID,以确定每一处要渲染的内容,这类带 name 的插槽被称为具名插槽 (named slots)。没有提供 name 的 <slot> 出口会隐式地命名为“default”。

<!-- 封装组件 -->
<template>
  <div class="title">
    <slot name="title"></slot>
  </div>
  <div class="right">
    <slot name="option"></slot> 
  </div>
</template>


<!-- 应用组件 -->
<template>
   <myComponent>
      <!-- title 插槽的内容放这里 -->
      <template v-slot:title>标题</template>

      <!-- option 插槽的内容放这里 -->
      <template v-slot:option>
          <el-button type="primary" link>操作</el-button>
      </template>

   </myComponent>
</template>

11、v-pre:跳过该元素及其子元素的编译,最常见的就是显示原始双括号标签及内容。

<span v-pre>{{ this will not be compiled }}</span>

12、v-once:仅沉浸一次元素和组件,并跳过之后的更新。可以用来优化更新时的性能。

<!-- 单个元素 -->
<span v-once>This will never change: {{msg}}</span>
<!-- 带有子元素的元素 -->
<div v-once>
  <h1>comment</h1>
  <p>{{msg}}</p>
</div>
<!-- 组件 -->
<MyComponent v-once :comment="msg" />
<!-- `v-for` 指令 -->
<ul>
  <li v-for="i in list" v-once>{{i}}</li>
</ul>

13、v-memo:缓存一个模板的子树。在元素和组件上都可以使用。为了实现缓存,该指令需要传入一个固定长度的依赖值数组进行比较。如果数组里的每个值都与最后一次的渲染相同,那么整个子树的更新将被跳过。

<div v-memo="[valueA, valueB]">
  ...
</div>

当组件重新渲染,如果 valueA 和 valueB 都保持不变,这个 <div> 及其子项的所有更新都将被跳过。实际上,甚至虚拟 DOM 的 vnode 创建也将被跳过,因为缓存的子树副本可以被重新使用。

正确指定缓存数组很重要,否则应该生效的更新可能被跳过。v-memo 传入空依赖数组 (v-memo="[]") 将与 v-once 效果相同。

与 v-for 一起使用

v-memo 仅用于性能至上场景中的微小优化,应该很少需要。最常见的情况可能是有助于渲染海量 v-for 列表 (长度超过 1000 的情况),当搭配 v-for 使用 v-memo,确保两者都绑定在同一个元素上。v-memo 不能用在 v-for 内部。

<div v-for="item in list" :key="item.id" v-memo="[item.id === selected]">
  <p>ID: {{ item.id }} - selected: {{ item.id === selected }}</p>
  <p>...more child nodes</p>
</div>

14、v-cloak:用于隐藏尚未完成编译的 DOM 模板。

当使用直接在 DOM 中书写的模板时,可能会出现一种叫做“未编译模板闪现”的情况:用户可能先看到的是还没编译完成的双大括号标签,直到挂载的组件将它们替换为实际渲染的内容。

v-cloak 会保留在所绑定的元素上,直到相关组件实例被挂载后才移除。配合像 [v-cloak] { display: none } 这样的 CSS 规则,它可以在组件编译完毕前隐藏原始模板。

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

[v-cloak] {
  display: none;
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值