简单的vuex 的使用案例笔记


Posted in Javascript onApril 13, 2018

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: '<App/>',
 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:

<div class='modal' @click="changeModel">
 <div class="avatar">
 <img src="../../assets/img/logo.png" width="18" height="18">
 </div>
 <div class="name">
 {{currentModel}}
 </div> 
 <!-- vuex 相当于全局注入 vuex 然后取这里面的值 -->
</div>

js:

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

注意:

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

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

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

截图如下:

简单的vuex 的使用案例笔记

默认方式:

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

  点击事件触发模式;

简单的vuex 的使用案例笔记

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

简单的vuex 的使用案例笔记

结束语:

简单的vuex 的案例 ,做个笔记。希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jquery隐藏标签和显示标签的实例
Nov 11 Javascript
Bootstrap表单布局
Jul 19 Javascript
jQuery实现的模拟弹出窗口功能示例
Nov 24 Javascript
使用BootStrap建立响应式网页——通栏轮播图(carousel)
Dec 21 Javascript
EasyUI折叠表格层次显示detailview详解及实例
Dec 28 Javascript
vue组件watch属性实例讲解
Nov 07 Javascript
element-ui 关于获取select 的label值方法
Aug 24 Javascript
element-ui 上传图片后清空图片显示的实例
Sep 04 Javascript
vue.js父子组件通信动态绑定的实例
Sep 28 Javascript
微信小程序学习笔记之表单提交与PHP后台数据交互处理图文详解
Mar 28 Javascript
vue-列表下详情的展开与折叠案例
Jul 28 Javascript
JS中forEach()、map()、every()、some()和filter()的用法
May 11 Javascript
angular实现页面打印局部功能的思考与方法
Apr 13 #Javascript
vuex中的 mapState,mapGetters,mapActions,mapMutations 的使用
Apr 13 #Javascript
js捆绑TypeScript声明文件的方法教程
Apr 13 #Javascript
详解vuex中mapState,mapGetters,mapMutations,mapActions的作用
Apr 13 #Javascript
使用sessionStorage解决vuex在页面刷新后数据被清除的问题
Apr 13 #Javascript
如何编写一个d.ts文件的步骤详解
Apr 13 #Javascript
VSCode中如何利用d.ts文件进行js智能提示
Apr 13 #Javascript
You might like
农民和部队如何穿矿
2020/03/04 星际争霸
PHP 编程安全性小结
2010/01/08 PHP
PHP中foreach循环中使用引用要注意的地方
2011/01/02 PHP
php7 安装yar 生成docker镜像
2017/05/09 PHP
javascript 函数声明与函数表达式的区别介绍
2013/10/05 Javascript
chrome下jq width()方法取值为0的解决方法
2014/05/26 Javascript
localResizeIMG先压缩后使用ajax无刷新上传(移动端)
2015/08/11 Javascript
分享一些常用的jQuery动画事件和动画函数
2015/11/27 Javascript
js获取本机操作系统类型的两种方法
2015/12/19 Javascript
js获取腾讯视频ID的方法
2016/10/03 Javascript
简单谈谈JS数组中的indexOf方法
2016/10/13 Javascript
react-router v4如何使用history控制路由跳转详解
2018/01/09 Javascript
小程序实现发表评论功能
2018/07/06 Javascript
AngularJS实现的鼠标拖动画矩形框示例【可兼容IE8】
2019/05/17 Javascript
express框架中使用jwt实现验证的方法
2019/08/25 Javascript
微信小程序canvas分享海报功能
2019/10/31 Javascript
详解vue页面首次加载缓慢原因及解决方案
2019/11/06 Javascript
vue使用screenfull插件实现全屏功能
2020/09/17 Javascript
python连接sql server乱码的解决方法
2013/01/28 Python
python字符串连接的N种方式总结
2014/09/17 Python
Python3 itchat实现微信定时发送群消息的实例代码
2019/07/12 Python
python实现滑雪者小游戏
2020/02/22 Python
推荐8款常用的Python GUI图形界面开发框架
2020/02/23 Python
python中元组的用法整理
2020/06/15 Python
Python 存取npy格式数据实例
2020/07/01 Python
matplotlib绘制鼠标的十字光标的实现(自定义方式,官方实例)
2021/01/10 Python
利用css3画个同心圆示例代码
2017/07/03 HTML / CSS
预订全球最佳旅行体验:Viator
2018/03/30 全球购物
MySQL面试题
2014/01/12 面试题
幼儿园大班毕业感言
2014/02/06 职场文书
党员创先争优活动总结
2014/05/04 职场文书
水污染治理工程专业求职信
2014/06/14 职场文书
八一建军节营销活动方案
2014/08/31 职场文书
优秀员工推荐材料
2014/12/20 职场文书
Django实现在线无水印抖音视频下载(附源码及地址)
2021/05/06 Python
Java实现多文件上传功能
2021/06/30 Java/Android