位置: IT常识 - 正文

【vue2】vuex的安装、配置与使用(怎么安装vue2.0)

编辑:rootadmin
【vue2】vuex的安装、配置与使用 一、前言

推荐整理分享【vue2】vuex的安装、配置与使用(怎么安装vue2.0),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vuex怎么安装,vue的安装,vue2.0安装,vue安装vuex,vue安装vuex,vue安装vuex,vue2.0安装,vuex安装 报错,内容如对您有帮助,希望把文章链接给更多的朋友!

使用vuex可以实现数据的共享。

二、安装

vscode中新建终端安装vuex。由于vue2不能使用vuex4的版本,所以在安装时需要指定版本3

npm i vuex@3三、vuex工作流

vuex核心包括actions、mutations、state。

①state用来存储数据;

②actions用来响应组件的事件,也可以对数据进行加工,或者进行后端请求,也就是说组件中调用dispatch方法,可以触发actions中的方法;

③mutations用来操作state,actions中调用commit方法来调用mutations。

④其他:当不需要对数据进行额外加工的时候,可以直接在组件中调用commit方法触发mutations中的方法

四、配置

步骤一:新建文件夹store,文件夹下新建index.js文件

步骤二:index.js中完成配置:还没有配置数据和事件

import Vue from 'vue'import Vuex from 'vuex'Vue.use(Vuex)// 用来存储数据const state = {}// 响应组件中的事件const actions = {}// 操作数据const mutations = {}// 用来将state数据进行加工const getters = {}// 新建并暴露storeexport default new Vuex.Store({ state, actions, mutations, getters})

步骤三:main.js中引入

import Vue from 'vue'import App from './App.vue'import store from './store/index';Vue.config.productionTip = falsenew Vue({ render: h => h(App), store}).$mount('#app')五、使用

5.1、常规写法

【vue2】vuex的安装、配置与使用(怎么安装vue2.0)

1、state

组件中使用$store.state.xxx获取值,例如:

<li v-for="p in $store.state.person" :key="p.id"> 姓名:{{ p.personName }} 年龄:{{ p.age }} <button @click="deletePerson(p.id)">删除</button></li>

vuex的index.js:

const state = { person: [ { id: nanoid(), personName: "张三", age: 18 }, { id: nanoid(), personName: "张4", age: 28 }, { id: nanoid(), personName: "张5", age: 38 }, ]}

2、getter

组件中使用$store.getters.xxx获取getters中的返回值

<span> 学生年龄总和:{{ $store.getters.getAllPersonAge }} </span>

index.js:

// 用来将state数据进行加工:类似于computedconst getters = { getAllPersonAge(state) { var sumAge = 0; state.person.forEach(element => { sumAge += element.age }); return sumAge }}

3、actions

组件中使用this.$store.dispatch("aaa", xxx)触发actions中的aaa方法,参数为xxx

<input type="text" v-model="newPerson" /><button @click="addPerson">添加</button>addPerson() { if (this.newPerson == "") { alert("请输入姓名"); return; } this.$store.dispatch("addPerson", this.newPerson); this.newPerson=""},

index.js

// 响应组件中的事件const actions = { //添加人员 addPerson(content, value) { console.log(value) const person = { id: nanoid(), personName: value, age: 18//暂时写死 } content.commit("addPerson", person) }}

4、mutations

组件中:

<button @click="deletePerson(p.id)">删除</button>deletePerson(id) { this.$store.commit("deletePerson", id);},

index.js

const mutations = { addPerson(_, value) { this.state.person.unshift(value) }, deletePerson(_, id) { const newArr = this.state.person.filter(p => { return p.id != id }) this.state.person = newArr }}

5.2 四个map写法

上述写法都需要手动写this.$store.xxx比较麻烦,可以在组件中引入vuex的四个map,简化操作

组件中引入:

import { mapState, mapActions, mapGetters, mapMutations } from "vuex";

使用:

computed: { ...mapState(["person"]), ...mapGetters(["getAllPersonAge"]),},methods: { ...mapActions({ addPerson1: "addPerson", //第一个为本地方法名,第二个参数为actions中的方法名}), ...mapMutations(["deletePerson"]),//当本地和index.js中的方法名一致时,可以简化成数组写法},

使用:直接使用上面中定义的参数名

<input type="text" v-model="newPerson" /> <button @click="addPerson1(newPerson)">添加</button> <ul> <li v-for="p in person" :key="p.id"> 姓名:{{ p.personName }} 年龄:{{ p.age }} <button @click="deletePerson(p.id)">删除</button> </li> </ul> <span> 学生年龄总和:{{ getAllPersonAge }} </span>五、其他

以上就是vuex的所有介绍,我们一起进步。

本文链接地址:https://www.jiuchutong.com/zhishi/290785.html 转载请保留说明!

上一篇:阿尔高阿尔卑斯山脉的Schrecksee湖,德国巴伐利亚 (© Andreas Hagspiel/EyeEm/Getty Images)(阿尔卑斯山百度百科)

下一篇:JavaScript includes() 方法

  • 商品房价格居高不下的原因
  • 一般纳税人的增值税征收方式的特点是
  • 核定征收的计算方法有哪些
  • 印花税怎么计提和缴纳
  • 工伤保险应该计入什么科目
  • 个体户生产经营个人所得税
  • 合同资产在资产负债表中列入什么项目
  • 劳务费发票入账在所得税中有何规定
  • 固定资产大修理支出标准
  • 政府给的专款专用发票
  • 预缴的所得税怎么做分录
  • 更新改造过程中被替换部件的账面价值
  • 房地产开发企业销售自行开发的房地产项目
  • 写字楼出租流程
  • 借款利息可以入账吗
  • 高新技术企业退税比例是多少
  • 培训费发票如何入账
  • 收到快递关税做什么科目
  • 小规模可以不报增值税吗
  • 计提其他应收款坏账
  • 预收贷款是什么会计科目
  • 收到借出款利息会计分录
  • 开发票时的数据可以四舍五入吗
  • 向房东要押金的不犯法的妙招
  • 域名怎么交费
  • 商品购进核算
  • 自费出版的书籍可以售卖吗
  • e卡 叠加
  • 马拉喀什的历史背景
  • 前端打包后生成文件
  • 网上打印企业征信报告
  • init 4命令
  • 固定资产的销售怎么做账
  • 出租改自用房产税
  • 水电费发票如何分配给客户
  • 用友t3财务报表导出
  • 什么是预付账款的管理重点
  • 非流动资产基金 新会计制度 对应
  • 旅游公司差额征税如何开票
  • 一万元,两分的利息,一年利息是多少
  • 高新企业申报条件有哪些
  • 固定资产科目代码是多少
  • 销售返利可以税前扣除吗
  • 生活服务业可以开具增值税专用发票
  • 公司租赁房屋房产税
  • 一个企业只有收入怎么办
  • 增值税普通发票查询
  • 外资企业所得税优惠政策
  • 总公司中标走子公司账户违法吗
  • 填写增值税纳税申报怎么填写?
  • 解析视频
  • 科普知识手抄报简单又漂亮
  • 为什么总让升级浏览器
  • win2003注册表空间不足
  • ubuntu安装ubuntu-desktop
  • centos清理磁盘空间
  • ubuntu屏幕突然变大
  • ubuntu独立显卡黑屏
  • win8系统安装步骤
  • exfat装win7
  • win10系统玩lol弹出来
  • centos mail命令
  • 查看电脑是否可以装两个固态
  • PHPMyAdmin 2.7.0-pl1下载
  • win10 rs3
  • win10系统怎么卸载ie浏览器
  • win10系统电脑关机自动重启
  • js里的this指向
  • 简述ajax
  • javascript中的继承
  • 搭建简单的spike课程
  • Javascript在网页设计中的作用有哪些
  • jquery中点击事件点击没动静
  • 昆明地税局长是谁
  • 2024年深圳房价
  • 从事农业种植是干什么的
  • 新疆中国邮政投诉电话
  • 农产品电子发票可以抵扣吗
  • 个人的社会信用代码怎么查
  • 潍坊市市区
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设