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的一些特性和用法整理小结
Jan 13 Javascript
提取字符串中年月日的函数代码
Nov 05 Javascript
Javascript脚本实现静态网页加密实例代码
Nov 05 Javascript
使用requestAnimationFrame实现js动画性能好
Aug 06 Javascript
js的form表单提交url传参数(包含+等特殊字符)的两种解决方法
May 25 Javascript
vue + socket.io实现一个简易聊天室示例代码
Mar 06 Javascript
jQuery Plupload上传插件的使用
Apr 19 jQuery
JavaScript之Date_动力节点Java学院整理
Jun 28 Javascript
微信小程序实现分享商品海报功能
Sep 30 Javascript
Vue的click事件防抖和节流处理详解
Nov 13 Javascript
Vue项目如何引入bootstrap、elementUI、echarts
Nov 26 Vue.js
Vue深入理解插槽slot的使用
Aug 05 Vue.js
浅谈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
一个PHP日历程序
2006/12/06 PHP
PHP防止跨域提交表单
2013/11/01 PHP
getJSON跨域SyntaxError问题分析
2014/08/07 PHP
php生成过去100年下拉列表的方法
2015/07/20 PHP
浅谈PHP实现大流量下抢购方案
2017/12/15 PHP
日期函数扩展类Ver0.1.1
2006/09/07 Javascript
[转]JS宝典学习笔记
2007/02/07 Javascript
js下写一个事件队列操作函数
2010/07/19 Javascript
javascript数组操作(创建、元素删除、数组的拷贝)
2014/04/07 Javascript
DOM事件阶段以及事件捕获与事件冒泡先后执行顺序(图文详解)
2015/08/18 Javascript
JavaScript实现非常简单实用的下拉菜单效果
2015/08/27 Javascript
fckeditor部署到weblogic出现xml无法读取及样式不能显示问题的解决方法
2017/03/24 Javascript
推荐三款不错的图片压缩上传插件(webuploader、localResizeIMG4、LUploader)
2017/04/21 Javascript
最新Javascript程序员面试试题和解题方法
2017/11/23 Javascript
完美解决手机浏览器顶部下拉出现网页源或刷新的问题
2017/11/30 Javascript
使用js和canvas实现时钟效果
2020/09/08 Javascript
vue 项目引入echarts 添加点击事件操作
2020/09/09 Javascript
Python实现单词拼写检查
2015/04/25 Python
python嵌套字典比较值与取值的实现示例
2017/11/03 Python
使用Scrapy爬取动态数据
2018/10/21 Python
对python pandas 画移动平均线的方法详解
2018/11/28 Python
浅析python参数的知识点
2018/12/10 Python
Python类的继承、多态及获取对象信息操作详解
2019/02/28 Python
Python中IP地址处理IPy模块的方法
2019/08/16 Python
澳大利亚在线购买儿童玩具:Toy Universe
2017/12/28 全球购物
Under Armour安德玛法国官网:美国高端运动科技品牌
2018/06/29 全球购物
ktv筹备计划书
2014/05/03 职场文书
村委会换届选举方案
2014/05/03 职场文书
预备党员转正考核材料
2014/06/03 职场文书
乒乓球兴趣小组活动总结
2014/07/08 职场文书
教师个人读书活动总结
2014/07/08 职场文书
运动会广播稿150字(9篇)
2014/09/20 职场文书
绍兴鲁迅故居导游词
2015/02/09 职场文书
运动会3000米加油稿
2015/07/21 职场文书
2016党校培训心得体会
2016/01/07 职场文书
Go语言基础切片的创建及初始化示例详解
2021/11/17 Golang