IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vuex的四个辅助函数 -> 正文阅读

[JavaScript知识库]Vuex的四个辅助函数

?mapState,mapGetters,mapActions,mapMutations

映射到state数据的state 我们无需再使用 this.$store....,简化操作

这里我们以mapState和mapActions为例

组件页面

<template>
    <div>
        <h2>Vuex四个辅助函数的应用</h2>

        <div class="formCon">
            <el-input v-model="name" placeholder="请输入姓名">></el-input>
            <el-button type="primary" size="small" @click="add(name)">添加</el-button>
        </div>

        <div class="listCon">
            <ul>
                <li v-for="p in personList" :key="p.ids">{{p.ids}}---{{p.name}}</li>
            </ul>
        </div>

    </div>
</template>

<script>
import {mapState,mapGetters,mapActions,mapMutations} from 'vuex'
export default {
    name: 'Vue2TestStatic1',

    data() {
        return {
            name:"",
        };
    },
    computed:{
        // 拿到vuex里面的人员列表
        ...mapState('person',['personList']),
        
    },

    mounted() {
        
    },

    methods: {
        add(name){
            this.updatePerson(name)
            this.name= '';
        },

        ...mapActions('person',['updatePerson'])
    },
};
</script>

<style lang="scss" scoped>
.formCon{
    display: flex;
    .el-button {
        margin-left: 15px;
    }
}
.listCon{
    width: 400px;
    margin-top: 20px;
    border: 1px solid skyblue;
}
</style>

person.js? ?使用namespaced:true开启命名空间? 可以使我们指定那个模块

这里借助nanoid 随机生成ids

import { nanoid } from 'nanoid'
// 数据
const state = {
    
    personList:[
        {
            name:'张三',
            ids:'SxrDuRF7qQ_5mwmCKf3Oj'
        },
        {
            name:'李四',
            ids:'SxrDuRF7qQ_5mwmC443Oj'
        }
    ],
    
}

// mutations操作数据
const mutations = {
    // 添加人员信息
    ADD_PERSON(state,personObj){
        state.personList.push(personObj);
    },
  
}
// actions进行异步操作 给外界方法 等待触发
const actions = {
    updatePerson(contenxt,name){
        contenxt.commit('ADD_PERSON',{ids:nanoid(),name:name})
    },
}

// 导出
export default {
  // 开启命名空间
  namespaced:true,
  state,
  mutations,
  actions
}

结果:

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-29 12:02:02  更:2022-04-29 12:04:24 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 4:18:31-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码