vue3 Composition API使用示例教程
Vue3新增了Composition API。我们只需将实现某一功能的相关代码全部放进一个函数中,然后return需要对外暴露的对象。不同功能的代码都是一个个函数,最终在setup()函数中导入这些函数API,来使用这些功能。
在Vue3中,我们在小型组件仍可以继续沿用Options API,而对于大型组件则推荐使用Composition API。
Composition API没有this,如果要获取实例可以通过gitCurrentInstance这个函数,要使用它,需要手动引入,Composition API的生命周期,ref,toRef等要使用的话也是需要手动引入的。
<script>
import { useStore } from "vuex";
import { getCurrentInstance } from 'vue'
export default {
name: "ChildA",
setup() {
const instance = getCurrentInstance();
console.log('instance--',instance);
return {};
},
};
</script>用reactive定义响应数据,reactive作用将一个普通对象转换成响应式对象,和vue2里面的Options里面的data一样里面的数据都是响应式的。
生命周期也发生了一些变化,setup是beforeCreate和created的组合,vue3中的生命周期除了卸载阶段名称变了,变成onbeforeUnmount和onUnmounted,其它的只是在前面添加了一个on。
vuex在Composition中使用,手动移入vuex,用reactive定义响应式数据,该数据有属性goods,函数在onMounted生命周期中调用,生命周期中传入的是一个函数。调用vuex的方法,执行后直接给响应式数据属性赋值就行了。
最后在调用toRef或者toRefs对响应式数据属性做个处理,做个处理就可以直接使用这个属性(直接goods),不需要再去用“state.goods"的方式使用了。toRef或toRefs变量命名建议用xxx.Ref和xxx.Refs。
ref生成一个响应式数据,可用于模板和reactive(用于模板和reactive不需要通过.value),通过.value修改值。
toRef针对响应式对象的一个属性生成一个ref,ref具有响应式,二者保持引用关系。
toRefs将响应式对象转换成普通对象,对象的每个属性都是一个ref,二者保持引用关系。
要使用Composition中的方法也需要通过renturn导出。
<script>
import { useStore } from "vuex";
import { reactive, onMounted, toRef, toRefs } from 'vue'
export default {
name: "ChildA",
setup() {
const store = useStore();
const state = reactive({
goods:[]
});
const getData = () => {
store.dispatch("products/getProducts").then((res) => {
state.goods = res
});
};
const addData = () => {
store.dispatch("products/setProducts");
getData();
};
onMounted(() => {
getData();
});
//以toRef形式返回
const goodsRef = toRef(state,'goods');
return { goodsRef, addData };
//以toRefs形式返回
/* const goodsRefs = toRefs(state);
return goodsRefs */
},
};
</script>模板中使用
<template>
<div class="child-a">
ChildA:
<ul>
<!-- 以toRefs形式返回直接取响应式对象属性 -->
<!-- <li v-for="item in goods" :key="item.id">{{ item.name }}</li> -->
<!-- 以toRef形式返回 -->
<li v-for="item in goodsRef" :key="item.id">{{ item.name }}</li>
</ul>
<button @click="addData">ChildA-Add</button>
</div>
</template>到此这篇关于vue3 Composition API使用的文章就介绍到这了,更多相关vue3 Composition API使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Vue 项目中如何使用fullcalendar 时间段选择插件(类似课程表格)
最近完成一个项目,需要选择一个会议室,但是最好能够通过在图上显示出该 会议室在某某时间段内已经被预定了,初看这个功能感觉很棘手,仔细分析下实现起来还是挺容易的,下面通过示例代码讲解Vue项目中使用fullcalendar时间段选择插件,感兴趣的朋友一起看看吧2024-07-07
vue3+arco design通过动态表单方式实现自定义筛选功能
这篇文章主要介绍了vue3+arco design通过动态表单方式实现自定义筛选,本文主要实现通过动态表单的方式实现自定义筛选的功能,用户可以自己添加筛选的项目,筛选条件及筛选内容,需要的朋友可以参考下2024-05-05


最新评论