Vue3 Composition API 中使用 Vuex
下面是一个Vue3 Composition API 中使用Vuex的实例todoList,用到了state,mutations,actions,可以把自己之前用vue2的旧语法改写成vue3的语法,使用setup,ref, reactive, toRefs,useStore等,完整代码指路:github: color-library。
<!-- todoList.vue -->
<template>
<div class="todo-list-wrap">
<h2>{{ title }}</h2>
<div class="name-wrap">
<h3>{{ name }}</h3>
<el-button @click="handleChangeName">
修改
</el-button>
<el-button @click="handleRestoreName">
还原
</el-button>
</div>
<div class="input-wrap">
<el-input v-model="inputVal" @keyup.enter="handleAddItem"></el-input>
<el-button @click="handleAddItem">
新增
</el-button>
</div>
<div class="list-item-wrap">
<div v-for="(item,index) in dataList" :key="index" class="list-item">
<span>{{ item }}</span>
</div>
</div>
</div>
</template>
<script>
import { ref, reactive, toRefs } from 'vue'
import { useStore } from 'vuex'
export default {
name: 'TodoList',
setup() {
const title = ref('TodoList')
const store = useStore()
const { name } = toRefs(store.state) // 解构
const inputVal = ref('')
const dataList = reactive([])
const handleAddItem = ()=> {
dataList.push(inputVal.value)
inputVal.value = ''
}
const handleChangeName = ()=> {
// commit和mutations做关联,提交一个commit,触发一个mutation
store.commit('changeName', 'Happy')
}
const handleRestoreName = ()=> {
// dispatch和actions做关联,派发一个action
store.dispatch('getData', 'Biblee')
}
return {
title,
name,
inputVal,
dataList,
handleAddItem,
handleChangeName,
handleRestoreName
}
}
}
</script>
<style lang="scss" scoped>
.todo-list-wrap {
padding: 20px;
}
.name-wrap {
margin: auto;
display: flex;
justify-content: center;
align-items: center;
}
.input-wrap {
width: 300px;
margin: auto;
display: flex;
}
.el-button {
margin-left: 8px;
}
.list-item-wrap {
padding: 16px;
.list-item {
text-align: left;
}
}
</style>
store:
// store/index.js
import { createStore } from "vuex"
export default createStore({
state: {
name: 'Biblee'
},
// 同步操作
mutations: {
changeName(state, val) {
state.name = val
}
},
// 异步操作
actions: {
getData(store, val) {
setTimeout(()=>{
store.commit('changeName',val)
},2000)
}
},
modules: {
}
})
本文来自博客园,作者:叶子玉,转载请注明原文链接:https://www.cnblogs.com/knuzy/p/15260442.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
2018-09-12 vue element-ui 实现点击查看审核记录