简单的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 相关文章推荐
重构Javascript代码示例(重构前后对比)
Jan 23 Javascript
js 判断一组日期是否是连续的简单实例
Jul 11 Javascript
百度多文件异步上传控件webuploader基本用法解析
Nov 07 Javascript
EasyUI修改DateBox和DateTimeBox的默认日期格式示例
Jan 18 Javascript
javascript内存分配原理实例分析
Apr 10 Javascript
webpack学习--webpack经典7分钟入门教程
Jun 28 Javascript
利用node.js如何创建子进程详解
Dec 09 Javascript
vue-router中的hash和history两种模式的区别
Jul 17 Javascript
微信小程序实现点击图片旋转180度并且弹出下拉列表
Nov 27 Javascript
vue路由 遍历生成复数router-link的例子
Oct 30 Javascript
在vue中使用vuex,修改state的值示例
Nov 08 Javascript
微信小程序实现底部弹出模态框
Nov 18 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
PHP初学入门
2006/11/19 PHP
如何用php生成扭曲及旋转的验证码图片
2013/06/07 PHP
Symfony2使用Doctrine进行数据库查询方法实例总结
2016/03/18 PHP
PHP使用反射机制实现查找类和方法的所在位置
2016/04/22 PHP
PHP框架实现WebSocket在线聊天通讯系统
2019/11/21 PHP
javascript json2 使用方法
2010/03/16 Javascript
js实现运动logo图片效果及运动元素对象sportBox使用方法
2012/12/25 Javascript
Jquery.addClass始终无效原因分析
2013/09/08 Javascript
js实现动画特效的文字链接鼠标悬停提示的方法
2015/03/02 Javascript
nodeJs爬虫获取数据简单实现代码
2016/03/29 NodeJs
基于Bootstrap重置输入框内容按钮插件
2016/05/12 Javascript
jQuery中deferred对象使用方法详解
2016/07/14 Javascript
原生JS实现左右箭头选择日期实例代码
2017/03/14 Javascript
nodejs操作mysql实现增删改查的实例
2017/05/28 NodeJs
详解微信小程序动画Animation执行过程
2020/09/23 Javascript
[02:31]《DAC最前线》之选手酒店现场花絮
2015/01/30 DOTA
Python正则表达式经典入门教程
2017/05/22 Python
python与sqlite3实现解密chrome cookie实例代码
2018/01/20 Python
PyQt5每天必学之像素图控件QPixmap
2018/04/19 Python
PyQt5每天必学之事件与信号
2018/04/20 Python
Python如何使用bokeh包和geojson数据绘制地图
2020/03/21 Python
html5基础标签(html5视频标签 html5新标签用法)
2013/12/30 HTML / CSS
GNC健安喜官方海外旗舰店:美国著名保健品牌
2017/01/04 全球购物
英国Office鞋店德国网站:在线购买鞋子、靴子和运动鞋
2018/12/19 全球购物
Jones Bootmaker官网:优质靴子和鞋子在线
2020/11/30 全球购物
你经历的项目中的SCM配置项主要有哪些?什么是配置项?
2013/11/04 面试题
工程技术员岗位职责
2014/03/02 职场文书
经销商订货会主持词
2014/03/27 职场文书
奥运会口号
2014/06/13 职场文书
销售类求职信
2014/06/13 职场文书
暑期社会实践心得体会
2014/09/02 职场文书
职工擅自离岗检讨书
2014/09/23 职场文书
劳动纠纷调解协议书格式
2014/11/30 职场文书
爱国影片观后感
2015/06/18 职场文书
最美劳动诗,致敬所有的劳动者!
2019/07/12 职场文书
Python max函数中key的用法及原理解析
2021/06/26 Python