vuex的传值步骤,详细

  1.  src新建一个vuex文件夹
  2. vuex文件夹里新建一个store.js
  3. 安装vuex cnpm install vuex --save
  4.  在刚才创建的store.js 中引入vue、vuex 引入vue
import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)

5 定义数据 state在vuex中用于存储数据

var state = {  count:1,}

6定义方法 mutations里边放的是方法,方法主要用于改变state里边的数据

var mutations = {
    incCount(){
            ++state.count;
   }
}
   //类似于计算属性  state里边的数据改变时候触发的方法。 可以做一些操作 并且可以有返回值
var getterfl={
         completedCountChange(state){
         return state.count * 2 +'位';
        }
    }

Action 类似于 mutation,不同在于: Action 提交的是 mutation,而不是直接变更状态。Action 可以包含任意异步操作

var actionfl = {
  asynIncCount(context){  
//因此你可以调用context.commit来提交一个mutation  使用action需要用dispatch
      context.commit('incCount');
  }
}

7. 实例化 vuex

const store = new Vuex.Store({
            state,//state: state  简写
            mutations: mutations,//属性的简写是 mutations
    getters:getterfl,
       actions:actionfl,
})

8 对外暴露

export default  store;

9 在需要用的地方引入

import store from '../vuex/store.js'

10 注册store ,放在methods,data同级

export default {
    data(){
        return{}
    },
    store:store,
    methods:{
        incCount(){
            this.$store.commit('incCount');
        }
    }
}

11 使用vuex
使用数据: this.\$store.state.count
调用方法: this.$store.commit('incCount');

完成!!!!

 

适用场景:

父子组件、兄弟组件、无关系组件任意组件之间的传值

.品鉴:

Vuex本质上也是一种本地存储,比localStorage的单纯值传递多了方法、属性、异步方法等功能。但是因为是将内容本地化,所以就会被在浏览器中获取到。

 

  • 5
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
在uniapp项目中,可以使用vuex来进行组件之间的传值。使用vuex进行传值的好处是可以在全局范围内管理和共享数据。在使用vuex传值之前,需要先进行vuex的配置和初始化。 首先,在项目的src目录下创建一个store文件夹,然后在store文件夹下创建一个index.js文件。在index.js文件中,需要引入并使用Vue和Vuex,并创建一个新的Vuex.Store实例。 引用中提到的uni-app项目中,可以在创建的store实例中定义state、mutations和actions。state用于存储数据,mutations用于修改state中的数据,而actions则用于处理异步操作。 在需要传值的组件中,可以通过this.$store.state来获取state中的数据,通过this.$store.commit来触发mutations中的方法来修改state中的数据。如果需要进行异步操作,可以使用this.$store.dispatch来触发actions中的方法。 另外,如果需要在组件之间传递多层嵌套的值,可以使用provide和inject来实现。在祖组件中使用provide来提供数据,然后在孙组件中使用inject来接收数据。这样就可以在祖孙组件之间进行传值。 总结起来,uniapp使用vuex传值步骤如下: 1. 配置vuex,创建store实例。 2. 在state中定义需要共享的数据。 3. 在mutations中定义修改state的方法。 4. 在actions中处理异步操作。 5. 在需要传值的组件中使用this.$store.state获取数据,使用this.$store.commit来触发mutations中的方法来修改数据。 6. 如果需要在组件之间传递多层嵌套的值,可以使用provide和inject来实现。 需要注意的是,使用vuex传值时,要注意及时销毁事件监听或者仅仅在需要监听事件时注册事件。可以在页面的onLoad中注册监听,在onUnload中移除监听,或者使用uni.$once一次性的事件监听。另外,在使用uni.$on之前,要确保uni.$on已经定义完成,才能接收到uni.$emit传递数据。 这样,你就可以在uniapp项目中使用vuex来进行组件之间的传值了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [uniapp和vue组件之间的传值方法(父子传值,兄弟传值,跨级传值vuex)](https://blog.csdn.net/weixin_45811256/article/details/127604610)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [基于vue的教育商城的设计与实现](https://download.csdn.net/download/weixin_44269229/11578623)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值