Vuex实现数据增加和删除功能


Posted in Javascript onNovember 11, 2019

首先,我们要安装vuex,执行命令yarn add vuex

1.编写state数据

//vuex/index.js
import Vue from 'vue';
import Vuex from 'vuex';
Vue.use(Vuex);
const state = {
  bookList: [
   {id: 1, name: '西游记'},{id: 2, name: '水浒传'},
   {id: 3, name: '红楼梦'},{id: 4, name: '三国演义'}
  ]
}
export default new Vuex.Store({
  state
})

2.组件调用state数据进行展示

我们的目的是把state数据赋值给vue组件进行使用,其实,这里有两种常用方法

//Home.vue
<p v-for='item in bookList'>{ {item.name} }<p/>

//方法一:通过computed的计算属性直接赋值,computed属性可以在输出前,对data中的值进行改变,我们就利用这种特性把state值赋值给vue模板中的data进行使用
computed: {
  bookList( ) {
   return this.$store.state.bookList;
  }
}

//方法二:通过mapState的对象来赋值
import { mapState } from 'vuex';//首先在组件内引入mapState
computed: {
  ...mapState(['bookList'])
}

方式二是我们经常用到的简写方式

基本的数据获取,就是这样的实现,此时我们看页面,就会循环展示state中的bookList数据

3.利用mutation、action实现增加删除数据

//vuex/index.js
const mutations = {
  ADD_ITEM(state,item) {
   state.bookList.push(item)
  }
}
const mutations = {
  ADD_ITEM(state,item) {
   state.bookList.push(item)
  },
  DEL_ITEM(state,id) {
   state.bookList.map((v,i)=> {
     if(v.id == id){
      state.bookList.splice(i,1)
     }
   })
  }
}
const actions = {
  add_item({commit},item) {
   commit('ADD_ITEM',item)
  },
  del_item({commit},id) {
   commit('DEL_ITEM',id)
  }
}
export default new Vuex.Store({
  state,mutations,actions
})
//Home.vue
<button @click='add_item'>ADD</button>
<p v-for='item in bookList' @click='delItem(item.id)'>{ {item.name} }<p/>

import { mapState, } from 'vuex';

computed: {
  ...mapState(['bookList'])
}
methods: {
  add_item() {
   let newObject = {id:this.bookList.length,name:'葫芦娃'}
   this.$store.dispatch('add_item',newObject)
  },
  delItem(id) {
   this.$store.dispatch('del_item',id)
  }
}

利用action派发mutation事件,实现增加和删除的操作

这里有一个很重要的概念: mutation是唯一修改state的方法,而action是操作mutation触发commit修改state的方式

4.使用getters过滤state数据

//vuex/index.js
const getters = {
  newBookList:function( state ){
   return JSON.parse(JSON.stringify(state.bookList)).splice(0,1)
  }
}

这样,我们在组件内部这样输出

mounted( ) {
  console.log(this.$store.getters.newBookList)
  console.log(this.bookList)
}

我们通过JSON拷贝,既可以得到过滤之后的state数据(1条数据),也可以得到原state数据(4条数据),个人理解,getters的作用就在这里

以上这篇Vuex实现数据增加和删除功能就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript 闭包
Sep 15 Javascript
ie中js创建checkbox默认选中问题探讨
Oct 21 Javascript
window.onresize 多次触发的解决方法
Nov 08 Javascript
javascript实现瀑布流自适应遇到的问题及解决方案
Jan 28 Javascript
canvas绘制万花筒效果(代码分享)
Jan 20 Javascript
vue使用xe-utils函数库的具体方法
Mar 06 Javascript
使用vuex的state状态对象的5种方式
Apr 19 Javascript
纯JS实现出生日期[年月日]下拉菜单效果
Jun 01 Javascript
JavaScript实现简单计算器功能
Dec 19 Javascript
vue打包静态资源后显示空白及static文件路径报错的解决
Sep 02 Javascript
Javascript文本框脚本实现方法解析
Oct 30 Javascript
three.js中多线程的使用及性能测试详解
Jan 07 Javascript
VUE:vuex 用户登录信息的数据写入与获取方式
Nov 11 #Javascript
vue 实现通过vuex 存储值 在不同界面使用
Nov 11 #Javascript
使用vuex存储用户信息到localStorage的实例
Nov 11 #Javascript
JS中比较两个Object数组是否相等方法实例
Nov 11 #Javascript
vue把输入框的内容添加到页面的实例讲解
Nov 11 #Javascript
vue与django集成打包的实现方法
Nov 11 #Javascript
微信小程序监听用户登录事件的实现方法
Nov 11 #Javascript
You might like
php实现12306余票查询、价格查询示例
2014/04/17 PHP
非集成环境的php运行环境(Apache配置、Mysql)搭建安装图文教程
2016/04/12 PHP
PHP入门教程之正则表达式基本用法实例详解(正则匹配,搜索,分割等)
2016/09/11 PHP
PHP中的浅复制与深复制的实例详解
2017/10/26 PHP
php实现通过stomp协议连接ActiveMQ操作示例
2020/02/23 PHP
jQuery插件原来如此简单 jQuery插件的机制及实战
2012/02/07 Javascript
javascript验证上传文件的类型限制必须为某些格式
2013/11/14 Javascript
移动端H5开发 Turn.js实现很棒的翻书效果
2016/06/20 Javascript
JavaScript微信定位功能实现方法
2016/11/29 Javascript
利用jQuery实现简单的拖曳效果实例代码
2017/10/20 jQuery
AjaxUpLoad.js实现文件上传
2018/03/05 Javascript
对vue2.0中.vue文件页面跳转之.$router.push的用法详解
2018/08/24 Javascript
vue中使用input[type=&quot;file&quot;]实现文件上传功能
2018/09/10 Javascript
对vue下点击事件传参和不传参的区别详解
2018/09/15 Javascript
angular6根据environments配置文件更改开发所需要的环境的方法
2019/03/06 Javascript
vue+layui实现select动态加载后台数据的例子
2019/09/20 Javascript
jquery实现抽奖功能
2020/10/22 jQuery
PyTorch CNN实战之MNIST手写数字识别示例
2018/05/29 Python
Python判断以什么结尾以什么开头的实例
2018/10/27 Python
Python3多线程基础知识点
2019/02/19 Python
Python GUI编程 文本弹窗的实例
2019/06/11 Python
python  logging日志打印过程解析
2019/10/22 Python
python TK库简单应用(实时显示子进程输出)
2019/10/29 Python
HTML5 device access 设备访问详解
2018/05/24 HTML / CSS
Spongelle官网:美国的创意护肤洗护品牌
2019/05/15 全球购物
StubHub希腊:购买体育赛事、音乐会和剧院门票
2019/08/03 全球购物
服装创业计划书范文
2014/02/05 职场文书
大学生职业生涯规划书参考模板
2014/03/05 职场文书
支行行长竞聘演讲稿
2014/05/15 职场文书
意外伤害赔偿协议书
2014/09/16 职场文书
死者家属慰问信
2015/03/24 职场文书
离婚案件被告代理词
2015/05/23 职场文书
运动员代表致辞
2015/07/29 职场文书
一篇文章带你搞懂Python类的相关知识
2021/05/20 Python
Python可变与不可变数据和深拷贝与浅拷贝
2022/04/06 Python
Python图像处理库PIL详细使用说明
2022/04/06 Python