博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
简单的vuex 的使用
阅读量:6340 次
发布时间:2019-06-22

本文共 2241 字,大约阅读时间需要 7 分钟。

1、 npm install vuex 

2、 在src 下 新建文件夹 store (为什么是这个单词,vuex 是用来状态管理的,用储存一些组件的状态,取存贮,仓库之意),store 文件下 新建文件 index.js  (为什么是index.js? 在导入的时候,会第一选择这个叫index的文件) 

3、 index.js import 导入 vue 和vuex (import 是es6 的语法, es5 是 require), 代码如下:

  这里的demo 是一个 改变 app 的模式 的一个appellation ,选择是 夜间模式还是白天模式

import Vue from 'vue'import Vuex from 'vuex'Vue.use(Vuex)export default new Vuex.Store({  state: {    night: true,    text: '白天',    className: 'morning'  },  mutations: {    increment (state) {      state.night = !state.night;      state.text = state.night === true ? '晚上' : '白天';      state.className = state.night === true ? 'night' : 'morning';    }  }})

 

4、 main.js import 这个index.js 代码如下:

// The Vue build version to load with the `import` command// (runtime-only or standalone) has been set in webpack.base.conf with an alias.import Vue from 'vue'import App from './App'import router from './router'import store from './store' // 会找index.js  /* eslint-disable no-new */new Vue({  el: '#app',  router,  store, // 注入根组件,其他子组件 都可以引用  template: '
', components: { App }})

5、使用vuex 的状态

组件1:

dom :

<div class="header" :class="model">

js

computed: {    model() {      return this.$store.state.className // 是ninght 还是  morning    }  },

注意:

:class="model" 这个class 可以绑定一个方法传参数,可以直接用 js 表达式,可以绑定一个计算属性

组件2:

dom:

js:

computed: {    currentModel () {      return this.$store.state.text    }  },  methods: {    changeModel () {      // document.body.className='night'      this.$store.commit('increment')    }  }

注意:

s 中的 currentModel 和 dom 中的 {
{ currentModel }} 是一个,和 :class 可以跟表达方法一样 ,可以跟变量 ,表达方法 ,表达式 ( 这里灵活的模版方法,回头查看下源码,然后补充这的说明, vue模版为何如此强大!)

点击事件,触发方法 changeModel ,changeModel 触发 mutation 的方法,显示改变 值 ,这个是固定的语法, this.$store.commit('increment');

increment 可以在定义的时候,设置参数,传参数, this.$store.commit('increment', 'argumnet') , 在 mutation 里面  increment (state , arg) { .. = arg; ....};

截图如下:

默认方式:

 

 

如上图显示。默认的是,白天的模式,className 是 morning; 

  点击事件触发模式;

再次点击的时候,可以在改回来,这个窍门,就是 index.js 里面,increment 对 night 的变量 取 对 的一个逻辑方法。跟jq 里面的 toggle,类似

结束语:

简单的vuex 的案例 ,做个笔记,不对之处,欢迎大家批评指出; 这里是一个关于vuex 源码分析的文章,很长,有兴趣的同学可以研究研究

下面讲一个稍微进阶点的例子: 引入vuex 里面的  

mapState, mapGetters, mapActions, mapMutations

转载地址:http://tqeoa.baihongyu.com/

你可能感兴趣的文章
fiddler抓包HTTPS配置及代理设置
查看>>
for循环枚举法,全排列+dfs,补充浮点数注意事项
查看>>
位与十进制表
查看>>
计算属性传参
查看>>
打造无DLL版穿透防火墙Downloader
查看>>
maven 多bundle项目
查看>>
单链表
查看>>
枚举类型成员方法
查看>>
我的集合学习笔记--ArrayList
查看>>
K8s 一、(1、容器基本概念 2、k8s基本概念 )
查看>>
jdbcTemplate queryForObject 查询 结果集 数量
查看>>
【hibernate】Hibernate中save, saveOrUpdate, persist, merge, update 区别
查看>>
VS中的活动debug和活动cpu
查看>>
Directx11教程(57) 环境映射
查看>>
.NET辅助工具(附下载地址)
查看>>
display:block、inline、inline-block的区别及应用案例
查看>>
uva-10474-枚举-水题
查看>>
给一系列的div中的第一个添加class
查看>>
记录一次向TiDB数据库导入数据的例子
查看>>
客户端跳转与服务器端跳转
查看>>