vuex 的简单使用

转载来源:

作者:noahlam
链接:https://juejin.im/post/5afea06d6fb9a07a9c0476c1
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


第一步
新建一个.js 文件,名字位置任意,按照惯例,建议在/src/store 目录下(没有的话自己新建一个呗)
文件位置 /src/store/index.js

// 引入vue 和 vuex
import Vue from 'vue'
import Vuex from 'vuex'

// 这里需要use一下,固定写法,记住即可
Vue.use(Vuex)

// 直接导出 一个 Store 的实例
export default new Vuex.Store({
  // 类似 vue 的 data
  state: {
    name: 'oldName'
  },
  // 类似 vue 里的 mothods(同步方法)
  mutations: {
    updateName (state) {
      state.name = 'newName'
    }
  }
})

这一步其实就是新建一个store,但是我们还没在项目中使用.


第二步
在入口文件引入上述文件, 并稍微改一下传给 new Vue()的参数,新增的行后面有备注
文件位置 /src/main.js (vue-cli自动生成的入口,如果你能不用脚手架,那么也就不需要我说明了)

import Vue from 'vue'
import App from './App'
import vuexStore from './store'   // 新增

new Vue({
  el: '#app',
  store:vuexStore                 // 新增
  components: { App },
  template: '<App/>'
})

Tip: import store from ‘./store’
后面的地址,就是上面我们新建那个文件的位置(/src/store/index.js), 因为我这里是index.js,所以可以省略.

第三步
以上2步,其实已经完成了vuex的基本配置,接下来就是使用了

文件位置 /src/main.js (同样是vue-cli生成的app.vue,这里为了方便演示,我去掉多余的代码)

<template>
  <div>
    {{getName}}
    <button @click="changeName" value="更名">更名</button>
  </div>
</template>

<script>
import HelloWorld from './components/HelloWorld'

export default {
  computed:{
    getName(){
      return this.$store.state.name
    }
  },
  methods:{
    changeName () {
      this.$store.commit('updateName')
    }
  }
}
</script>

这里就是一个很普通的vue文件了,有区别的地方是这里我们需要用computed属性去获取 store 里的 “data”
还有就是我们要改变数据的话,不再用 this.xxx = xxx 改成 this.$store.commit(‘updateName’)

总结
你可能会觉得,上例这样做的意义何在,为何不直接用vue的data跟methods?
上例只是为了简单讲解如何使用vuex,所以简化了一些流程,试想一下,如果你有这样一个页面:
一共嵌套了10层组件(即子组件里面还有子子组件,子子组件下面还有子子子组件,以此类推10层)
然后最后一层组件一个数据改变了,要通知第一层组件的时候,我们只需在最底层组件里this. store.commit(),computed,. s t o r e . c o m m i t ( ) , 然 后 再 最 外 层 组 件 上 用 c o m p u t e d 属 性 获 取 对 应 的 值 , 就 能 做 到 实 时 更 新 . 无 需 层 层 emit上去.

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在手机端,使用Vuex可以方便地管理应用程序的状态。Vuex是一个专为Vue.js应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态的一致性。 在手机端使用Vuex,首先需要安装Vuex库。可以通过npm或者yarn进行安装。安装完成后,在Vue项目中创建一个store文件夹,并在该文件夹下创建一个index.js文件。 在index.js文件中,需要引入Vue和Vuex,并创建一个新的Vuex.Store实例。在该实例中,可以定义state、mutations、actions和getters等属性和方法。 state:用于存储应用程序的状态数据。 mutations:用于修改state中的数据。只能进行同步操作。 actions:用于处理异步操作,可以包含多个mutations的调用。 getters:用于获取state中的数据,类似于计算属性。 下面是一个简单的示例: ```javascript // index.js import Vue from 'vue'; import Vuex from 'vuex'; Vue.use(Vuex); const store = new Vuex.Store({ state: { count: 0 }, mutations: { increment(state) { state.count++; }, decrement(state) { state.count--; } }, actions: { incrementAsync(context) { setTimeout(() => { context.commit('increment'); }, 1000); } }, getters: { doubleCount(state) { return state.count * 2; } } }); export default store; ``` 在Vue组件中,可以通过this.$store来访问Vuex的状态和方法。例如: ```javascript // App.vue <template> <div> <p>Count: {{ $store.state.count }}</p> <p>Double Count: {{ $store.getters.doubleCount }}</p> <button @click="$store.commit('increment')">Increment</button> <button @click="$store.dispatch('incrementAsync')">Increment Async</button> </div> </template> <script> export default { name: 'App', mounted() { console.log(this.$store.state.count); } } </script> ``` 以上是手机端使用Vuex简单介绍,希望对你有帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值