Vue3.x 笔记

Vue 3 官网:https://v3.cn.vuejs.org/

以下是vue的学习笔记,大部分内容引用官网

1. 组件

1.1. 自定义事件

1.1.1. 事件名

与组件和 prop 一样,事件名提供了自动的大小写转换。如果在子组件中触发一个以 camelCase (驼峰式命名) 命名的事件,你将可以在父组件中添加一个 kebab-case (短横线分隔命名) 的监听器。

  1. this.$emit('myEvent')
  1. <my-component @my-event="doSomething"></my-component>

1.1.2. 定义自定义事件

通过 emits 选项在组件上定义发出的事件

  1. app.component('custom-form', {
  2. emits: ['inFocus', 'submit']
  3. })

当在 emits 选项中定义了原生事件 (如 click) 时,将使用组件中的事件替代原生事件侦听器。

1.1.3. 验证抛出的事件

prop 类型验证类似,定义发出的事件不是使用数组语法,而使用对象语法,则可以对它进行验证。
验证规则是定义成一个函数,该函数接收传递给 $emit 调用的参数,并返回一个布尔值用于验证事件是否有效。

  1. app.component('custom-form', {
  2. emits: {
  3. // 没有验证
  4. click: null,
  5. // 验证 submit 事件
  6. submit: ({ email, password }) => {
  7. if (email && password) {
  8. return true
  9. } else {
  10. console.warn('Invalid submit event payload!')
  11. return false
  12. }
  13. }
  14. },
  15. methods: {
  16. submitForm(email, password) {
  17. this.$emit('submit', { email, password })
  18. }
  19. }
  20. })

1.1.4. 为什么需要在组件上使用 v-model

v-model 是双向数据绑定指令,当需要维护组件内外数据的同步时,可以在组件上使用 v-model 指令。
01-Vue3.x-笔记 - 图1
上面示例图可以看出,外界数据的变化会自动同步到 counter 组件中。counter 组件中数据的变化,也会自动同步到外界

1.1.5. 在组件上使用 v-model 的步骤

01-Vue3.x-笔记 - 图2

  1. 父组件通过 v-bind: 属性绑定的形式,把数据传递给子组件
  2. 子组件中,通过 props 接收父组件传递过来的数据

01-Vue3.x-笔记 - 图3

  1. v-bind: 指令之前添加 v-model 指令
  2. 在子组件中声明 emits 自定义事件,格式为 update:xxx
  3. 调用 $emit() 触发自定义事件,更新父组件中的数据

    1.1.6. v-model 参数

    默认情况下,组件上的 v-model 使用 modelValue 作为 propupdate:modelValue 作为事件。如下例: ```
  1. 在本例中,子组件需要定义一个名为 `title` `prop` 属性,并需要定义一个名为 `update:title` 的事件来进行与父组件的同步:

app.component(‘my-component’, { props: { title: String }, emits: [‘update:title’], template: <input type="text" :value="title" @input="$emit('update:title', $event.target.value)"> })

  1. #### 1.1.7. 多个 v-model 绑定
  2. 单个组件实例上也可以使用多个 `v-model` 绑定参数。每个 `v-model` 将同步到不同的 `prop` 属性中,用法与单个 `v-model` 一样

<user-name v-model:first-name=”firstName” v-model:last-name=”lastName”

  1. ```
  2. app.component('user-name', {
  3. props: {
  4. firstName: String,
  5. lastName: String
  6. },
  7. emits: ['update:firstName', 'update:lastName'],
  8. template: `
  9. <input
  10. type="text"
  11. :value="firstName"
  12. @input="$emit('update:firstName', $event.target.value)">
  13. <input
  14. type="text"
  15. :value="lastName"
  16. @input="$emit('update:lastName', $event.target.value)">
  17. `
  18. })

1.1.8. 处理 v-model 修饰符(待整理)

1.2. Provide / Inject

如果需要从父组件传递给比较深层次结构的子组件(孙级以下组件),可以使用一对 provideinject,主要应用是,父组件有一个 provide 选项来提供数据,子组件有一个 inject 选项来开始使用这些数据。
01-Vue3.x-笔记 - 图4

1.2.1. 基础用法

在父组件通过 provide 属性共享数据

  1. data() {
  2. return {
  3. name: 'MooNkirA',
  4. }
  5. },
  6. provide() {
  7. /*
  8. 在 provide 共享数据,只要是与本组件有关系的子级或更深层级别的组件都能获取到这些数据
  9. 默认情况下,provide/inject 绑定并不是响应式的。
  10. */
  11. return {
  12. num: 1024,
  13. name: this.name,
  14. }
  15. },

在子级或者更深层级的组件中,通过 inject 属性来获取共享的数据

  1. /*
  2. 通过 inject 属性注入传递的数据,与定义 props 一样
  3. 子组件不需要知道 inject 的 property 来自哪里
  4. */
  5. inject: ['num', 'name'],

实际上,可以将依赖注入看作是“长距离的 prop”的传递:

  • 父组件不需要知道哪些子组件使用了它 provide 的 property
  • 子组件不需要知道 inject 的 property 来自哪里

    1.2.2. 处理响应性

    默认情况下,provide/inject 绑定并不是响应式的。想对祖先组件中的更改做出响应,我们需要为 provide 的 todoLength 分配一个组合式 API computed property: ``` import { computed } from ‘vue’

provide() { / 在 provide 共享数据,只要是与本组件有关系的子级或更深层级别的组件都能获取到这些数据 默认情况下,provide/inject 绑定并不是响应式的。 / return { num: 1024, name: this.name, // 通过 computed 的函数返回一个响应式的值 text: computed(() => this.text), } }

``` 更多组件式 API 用法,详见官网