Vuex 使用及简单实例(计数器)


Posted in Javascript onAugust 29, 2018

前一段时间因为需要使用vue,特地去学习了一下。但是时间匆忙vuex没有接触到,今天闲暇时看了解了一下vuex,并做了一个小demo,用于记录vuex的简单使用过程。

什么是Vuex?

vuex是专门为vue.js应用程序开发的一种状态管理模式,当多个视图依赖于同一个状态或是多个视图均可更改某个状态时,将共享状态提取出来,全局管理。

引入Vuex(前提是已经用Vue脚手架工具构建好项目)

1、利用npm包管理工具,进行安装 vuex。在控制命令行中输入下边的命令就可以了。

npm install vuex --save

要注意的是这里一定要加上 ?save,因为你这个包我们在生产环境中是要使用的。

2、新建一个store文件夹(这个不是必须的),并在文件夹下新建store.js文件,文件中引入我们的vue和vuex。

import Vue from 'vue';
import Vuex from 'vuex';

3、使用我们vuex,引入之后用Vue.use进行引用。

Vue.use(Vuex);

通过这三步的操作,vuex就算引用成功了,接下来我们就可以尽情的玩耍了。

4、在main.js 中引入新建的vuex文件

import storeConfig from './vuex/store'

5、再然后 , 在实例化 Vue对象时加入 store 对象 :

new Vue({
  el: '#app',
  router,
  store,//使用store
  template: '<App/>',
  components: { App }
 })

下面是一个计数器的例子

在src目录下创建一个store文件夹。

src/store.js

import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

const store = new Vuex.Store({
 state: {
 count: 0,
 show: ''
 },
 getters: {
 counts: (state) => {
  return state.count
 }
 },
 mutations: {
 increment: (state) => {
  state.count++
 },
 decrement: (state) => {
  state.count--
 },
 changTxt: (state, v) => {
  state.show = v
 }
 }
})

export default store

state就是我们的需要的状态,状态的改变只能通过提交mutations,例如:

handleIncrement () {
  this.$store.commit('increment')
 }

带有载荷的提交方式:

changObj () {
  this.$store.commit('changTxt', this.obj)
 }

当然了,载荷也可以是一个对象,这样可以提交多个参数。

changObj () {
  this.$store.commit('changTxt', {
   key:''
  })
 }

在main.js中引入store.js

import store from './store/store'
export default new Vue({
 el: '#app',
 router,
 store,
 components: {
 App
 },
 template: '<App/>'
})

在组件中使用

在组建可以通过$store.state.count获得状态

更改状态只能以提交mutation的方式。

<template>
<div class="store">
 <p>
 {{$store.state.count}}
 </p>
 <el-button @click="handleIncrement"><strong>+</strong></el-button>
 <el-button @click="handleDecrement"><strong>-</strong></el-button>
 <hr>
 <h3>{{$store.state.show}}</h3>
 <el-input
 placeholder="请输入内容"
 v-model="obj"
 @change="changObj"
 clearable>
 </el-input>
</div>
</template>
<script>
export default {
 data () {
 return {
  obj: ''
 }
 },
 methods: {
 handleIncrement () {
  this.$store.commit('increment')
 },
 handleDecrement () {
  this.$store.commit('decrement')
 },
 changObj () {
  this.$store.commit('changTxt', this.obj)
 }
 }
}
</script>

到这里这个demo就结束了,

Vuex 使用及简单实例(计数器)

感觉整个个过程就是一个传输数据的过程,有点类似全局变量,但是vuex是响应式的。

这里当然并没有完全发挥出全部的vuex,

vuex还在学习中,写这篇文章主要是记录其简单的使用过程。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JQuery中$之选择器用法介绍
Apr 05 Javascript
防止文件缓存的js代码
Jan 10 Javascript
读取input:file的路径并显示本地图片的方法
Sep 23 Javascript
javascript使用for循环批量注册的事件不能正确获取索引值的解决方法
Dec 20 Javascript
javascript中String对象的slice()方法分析
Dec 20 Javascript
JS实现统计复选框选中个数并提示确定与取消的方法
Jul 01 Javascript
weUI应用之JS常用信息提示弹层的封装
Nov 21 Javascript
微信小程序 使用canvas制作K线实例详解
Jan 12 Javascript
JavaScript条件判断_动力节点Java学院整理
Jun 26 Javascript
Vue中的组件及路由使用实例代码详解
May 22 Javascript
JavaScript中的连续赋值问题实例分析
Jul 12 Javascript
关于React Native使用axios进行网络请求的方法
Aug 02 Javascript
浅谈Vue.use的使用
Aug 29 #Javascript
微信小程序支付前端源码
Aug 29 #Javascript
微信小程序使用swiper组件实现类3D轮播图
Aug 29 #Javascript
javascript中UMD规范的代码推演
Aug 29 #Javascript
详解webpack自定义loader初探
Aug 29 #Javascript
在vue中使用SockJS实现webSocket通信的过程
Aug 29 #Javascript
微信小程序自定义select下拉选项框组件的实现代码
Aug 28 #Javascript
You might like
水质对咖图啡风味的影响具体有哪些
2021/03/03 冲泡冲煮
php产生随机数的两种方法实例代码 输出随机IP
2011/04/08 PHP
php中echo()和print()、require()和include()等易混淆函数的区别
2012/02/22 PHP
Smarty中的注释和截断功能介绍
2015/04/09 PHP
LINUX下PHP程序实现WORD文件转化为PDF文件的方法
2016/05/13 PHP
WordPress过滤垃圾评论的几种主要方法小结
2016/07/11 PHP
js动态生成指定行数的表格
2013/07/11 Javascript
两个数组去重的JS代码
2013/12/04 Javascript
常用的Javascript数据验证插件
2015/08/04 Javascript
JavaScript实现仿淘宝商品购买数量的增减效果
2016/01/22 Javascript
JS判断字符串变量是否含有某个字串的实现方法
2016/06/03 Javascript
JS利用正则表达式实现简单的密码强弱判断实例
2017/06/16 Javascript
webpack配置打包后图片路径出错的解决
2018/04/26 Javascript
jQuery常见的遍历DOM操作详解
2018/09/05 jQuery
vue.js实现的全选与全不选功能示例【基于elementui】
2018/12/03 Javascript
实例讲解JavaScript预编译流程
2019/01/24 Javascript
vue路由教程之静态路由
2019/09/03 Javascript
深入理解基于vue-cli的webpack打包优化实践及探索
2019/10/14 Javascript
javascript canvas API内容整理
2020/02/16 Javascript
JS如何操作DOM基于表格动态展示数据
2020/10/15 Javascript
Vue + ts实现轮播插件的示例
2020/11/10 Javascript
[54:30]Liquid vs Newbee 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/16 DOTA
Python 基础教程之包和类的用法
2017/02/23 Python
python深度优先搜索和广度优先搜索
2018/02/07 Python
Python交互式图形编程的实现
2019/07/25 Python
Keras之fit_generator与train_on_batch用法
2020/06/17 Python
亚瑟士美国官网:ASICS美国
2017/02/01 全球购物
中国电视购物:快乐购
2017/02/04 全球购物
夜班门卫岗位职责
2013/12/09 职场文书
kfc实习自我鉴定
2013/12/14 职场文书
新春文艺演出主持词
2014/03/27 职场文书
毕业生学校推荐信范文
2014/05/21 职场文书
小学师德师风整改措施
2014/10/27 职场文书
公司总经理岗位职责
2015/04/01 职场文书
毕业论文致谢怎么写
2015/05/14 职场文书
python绘制简单直方图(质量分布图)的方法
2022/04/21 Python