简单的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代码
Dec 01 Javascript
基于jquery的高性能td和input切换并可修改内容实现代码
Jan 09 Javascript
javascript函数作用域学习示例(js作用域)
Jan 13 Javascript
百度地图API之本地搜索与范围搜索
Jul 30 Javascript
React.js入门学习第一篇
Mar 30 Javascript
JS面试题---关于算法台阶的问题
Jul 26 Javascript
Vue-router 类似Vuex实现组件化开发的示例
Sep 15 Javascript
基于express中路由规则及获取请求参数的方法
Mar 12 Javascript
JavaScript设计模式之原型模式分析【ES5与ES6】
Jul 26 Javascript
layui自定义工具栏的方法
Sep 19 Javascript
微信小程序 button样式设置为图片的方法
Jun 19 Javascript
通过实例了解Render Props回调地狱解决方案
Nov 04 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
人大复印资料处理程序_输入篇
2006/10/09 PHP
php 定界符格式引起的错误
2011/05/24 PHP
解析PHP自带的进位制之间的转换函数
2013/06/08 PHP
PHP获取一年中每个星期的开始和结束日期的方法
2015/02/12 PHP
使两个iframe的高度与内容自适应,且相等
2006/11/20 Javascript
非常漂亮的JS代码经典广告
2007/10/21 Javascript
清除网页历史记录,屏蔽后退按钮!
2008/12/22 Javascript
javascript getElementsByClassName函数
2010/04/01 Javascript
基于jquery的划词搜索实现(备忘)
2010/09/14 Javascript
js为鼠标添加右击事件防止默认的右击菜单弹出
2013/07/29 Javascript
鼠标滑在标题上显示图片的JS代码
2013/11/19 Javascript
jQuery手机浏览器中拖拽动作的艰难性分析
2015/02/04 Javascript
bootstrap fileinput 上传插件的基础使用
2017/02/17 Javascript
node.js基于express使用websocket的方法
2017/11/09 Javascript
微信小程序实现上传word、txt、Excel、PPT等文件功能
2019/05/23 Javascript
JS控制GIF图片的停止与显示
2019/10/24 Javascript
基于JavaScript实现留言板功能
2020/03/16 Javascript
[01:38]完美世界DOTA2联赛(PWL)宣传片:第一站
2020/10/26 DOTA
Python 读写文件和file对象的方法(推荐)
2016/09/12 Python
Python实现统计文本文件字数的方法
2017/05/05 Python
Python编程flask使用页面模版的方法
2018/12/28 Python
python logging日志模块原理及操作解析
2019/10/12 Python
python实现拉普拉斯特征图降维示例
2019/11/25 Python
极简的HTML5模版
2015/07/09 HTML / CSS
比利时香水网上商店:NOTINO
2018/03/28 全球购物
Java中的基本数据类型所占存储空间大小固定的吗
2012/02/15 面试题
中专生自我鉴定范文
2014/02/02 职场文书
《再见了,亲人》教学反思
2014/02/26 职场文书
《小池塘》教学反思
2014/02/28 职场文书
企业文化宣传标语
2014/06/09 职场文书
2014年服务员个人工作总结
2014/12/23 职场文书
幼儿园开学报名通知
2015/07/16 职场文书
排球赛新闻稿
2015/07/17 职场文书
2016习总书记系列重要讲话心得体会
2016/01/15 职场文书
php TP5框架生成二维码链接
2021/04/01 PHP
Nginx实现负载均衡的项目实践
2022/03/18 Servers