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 相关文章推荐
jquery.pagination.js 无刷新分页实现步骤分享
May 23 Javascript
JS Map 和 List 的简单实现代码
Jul 08 Javascript
基于javascript 闭包基础分享
Jul 10 Javascript
javascript中动态加载js文件多种解决办法总结
Nov 15 Javascript
javascript中定义类的方法汇总
Dec 28 Javascript
js+jquery常用知识点汇总
Mar 03 Javascript
jquery计算鼠标和指定元素之间距离的方法
Jun 26 Javascript
JS+CSS实现自适应选项卡宽度的圆角滑动门效果
Sep 15 Javascript
图解prototype、proto和constructor的三角关系
Jul 31 Javascript
使用Node.js给图片加水印的方法
Nov 15 Javascript
html中创建并调用vue组件的几种方法汇总
Nov 17 Javascript
JavaScript模拟实现网易云轮播效果
Apr 04 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
ie6 动态缩略图不显示的原因
2009/06/21 PHP
PHP中数组的三种排序方法分享
2012/05/07 PHP
php调用KyotoTycoon简单实例
2015/04/02 PHP
PHP实现微信申请退款功能
2018/10/01 PHP
js获取本机的外网/广域网ip地址完整源码
2013/08/12 Javascript
js点击按钮实现水波纹效果代码(CSS3和Canves)
2016/09/15 Javascript
Vue.js双向绑定实现原理详解
2016/12/22 Javascript
Js apply方法详解
2017/02/16 Javascript
Angularjs中ng-repeat的简单实例
2017/08/25 Javascript
input 标签实现输入框带提示文字效果(两种方法)
2017/10/09 Javascript
微信小程序progress组件使用详解
2018/01/31 Javascript
vue弹窗消息组件的使用方法
2020/09/24 Javascript
详解如何从零开始搭建Express+Vue开发环境
2018/07/17 Javascript
使用electron将vue-cli项目打包成exe的方法
2018/09/29 Javascript
用VueJS写一个Chrome浏览器插件的实现方法
2019/02/27 Javascript
关于layui导航栏不展示下拉列表的解决方法
2019/09/25 Javascript
vue项目中播放rtmp视频文件流的方法
2020/09/17 Javascript
[04:52]2015国际邀请赛LGD战队晋级之路
2015/08/14 DOTA
python读取Android permission文件
2013/11/01 Python
简单介绍利用TK在Python下进行GUI编程的教程
2015/04/13 Python
Python的Django框架中forms表单类的使用方法详解
2016/06/21 Python
使用Python中的tkinter模块作图的方法
2017/02/07 Python
不知道这5种下划线的含义,你就不算真的会Python!
2018/10/09 Python
详解PANDAS 数据合并与重塑(join/merge篇)
2019/07/09 Python
Python数据处理篇之Sympy系列(五)---解方程
2019/10/12 Python
Python二维数组实现求出3*3矩阵对角线元素的和示例
2019/11/29 Python
Python对象的属性访问过程详解
2020/03/05 Python
python中tkinter窗口位置\坐标\大小等实现示例
2020/07/09 Python
pycharm 的Structure界面设置操作
2021/02/05 Python
Urban Outfitters英国官网:美国平价服饰品牌
2016/11/25 全球购物
德国高尔夫商店:Golfshop.de
2019/06/22 全球购物
活动总结怎么写啊
2014/05/07 职场文书
乡镇党委书记第三阶段个人整改措施
2014/09/16 职场文书
慰问信范文
2015/02/14 职场文书
倡议书的格式写法
2015/04/28 职场文书
关于环保的宣传稿
2015/07/23 职场文书