您现在的位置是:网站首页> 编程资料编程资料

10分钟带你上手Vue3中新增的API_vue.js_

2023-05-24 347人已围观

简介 10分钟带你上手Vue3中新增的API_vue.js_

1. 初始化项目

// ① npm i -g @vue/cli // ② vue create my-project // ③ npm install @vue/composition-api -S // ④ main,js import Vue from 'vue' import VueCompositionApi from '@vue/composition-api' Vue.use(VueCompositionApi)

2. setup方法

setup是vue3.x中新的操作组件属性的方法,它是组件内部暴露出所有的属性和方法的统一API。

2.1 执行时机

setup的执行时机在:beforeCreate 之后 created之前

setup(props, ctx) { console.log('setup') }, beforeCreate() { console.log('beforeCreate') }, created() { console.log('created') },

2.2 接受props数据

// 通过 setup 函数的第一个形参,接收 props 数据: setup(props) { console.log(props) }, // 在 props 中定义当前组件允许外界传递过来的参数名称: props: { p1: String } /* {} p1: "传值给 com-setup" get p1: ƒ reactiveGetter() set p1: ƒ reactiveSetter(newVal) __proto__: Object */

2.3 context

setup 函数的第二个形参是一个上下文对象,这个上下文对象中包含了一些有用的属性,这些属性在 vue 2.x 中需要通过 this 才能访问到,在 vue 3.x 中,它们的访问方式如下:

setup(props, ctx) { console.log(ctx) console.log(this) // undefined }, /* attrs: Object emit: ƒ () listeners: Object parent: VueComponent refs: Object root: Vue ... */

注意:在 setup() 函数中无法访问到 this

3. reactive

reactive函数接收一个普通函数,返回一个响应式的数据对象。

reactive函数等价于 vue 2.x 中的 Vue.observable() 函数,vue 3.x 中提供了 reactive() 函数,用来创建响应式的数据对象,基本代码示例如下:

4. ref

ref() 函数用来根据给定的值创建一个响应式的数据对象,ref() 函数调用的返回值是一个对象,这个对象上只包含一个 .value 属性:

4.1 在 reactive 对象中访问 ref 创建的响应式数据

当把 ref() 创建出来的响应式数据对象,挂载到 reactive() 上时,会自动把响应式数据对象展开为原始的值,不需通过 .value 就可以直接被访问,例如:

setup() { const refCount = ref(0) const state = reactive({refCount}) console.log(state.refCount) // 输出 0 state.refCount++ // 此处不需要通过 .value 就能直接访问原始值 console.log(refCount) // 输出 1 return { refCount } }

注意:新的 ref 会覆盖旧的 ref,示例代码如下:

setup() { // 创建 ref 并挂载到 reactive 中 const c1 = ref(0); const state = reactive({ c1 }); // 再次创建 ref,命名为 c2 const c2 = ref(9); // 将 旧 ref c1 替换为 新 ref c2 state.c1 = c2; state.c1++; console.log(state.c1); // 输出 10 console.log(c2.value); // 输出 10 console.log(c1.value); // 输出 0 }

5. isRef

isRef() 用来判断某个值是否为 ref() 创建出来的对象;应用场景:当需要展开某个可能为 ref() 创建出来的值的时候,例如:

import { ref, reactive, isRef } from "@vue/composition-api"; export default { setup() { const unwrapped = isRef(foo) ? foo.value : foo } };

6. toRefs

toRefs() 函数可以将 reactive() 创建出来的响应式对象,转换为普通的对象,只不过,这个对象上的每个属性节点,都是 ref() 类型的响应式数据。

7. computed计算属性

7.1 只读的计算属性

7.2 可读可写的计算属性

8. watch

watch() 函数用来监视某些数据项的变化,从而触发某些特定的操作,使用之前需要按需导入:

import { watch } from '@vue/composition-api'

8.1 基本用法

8.2 监视数据源

监视 reactive 类型的数据源:

监视 ref 类型的数据源:

export default { setup() { // 定义数据源 let count = ref(0); // 指定要监视的数据源 watch(count, (count, prevCount) => { console.log(count, prevCount) }) setInterval(() => { count.value += 2 }, 2000) console.log(count.value) return { count } } };

8.3 监听多个数据源

监视 reactive 类型的数据源:

export default { setup() { const state = reactive({count: 100, name: 'houfei'}) watch( // 监听count name [() => state.count, () => state.name], // 如果变换 执行以下函数 ([newCount, newName], [oldCount, oldName]) => { console.log(newCount, oldCount) console.log(newName, oldName) }, { lazy: true} // 在 watch 被创建的时候,不执行回调函数中的代码 ) setTimeout(() => { state.count += 2 state.name = 'qweqweewq' }, 3000
                
                

-六神源码网