uniapp中使用Vuex存储全局变量和方法

创建

  1. 先在项目的根目录下创建store文件夹并在文件夹中创建index.js
  2. index.js中写上这些
import Vue from "vue"
import Vuex from "vuex"
 
Vue.use(Vuex);
 
export default new Vuex.Store({
    state:{
        
    },
    mutations:{
         
    }
})
  1. main.js中加上这两行
import store from './store'  
Vue.prototype.$store = store

使用

index.js就相当于一个仓库
state中存放一些变量
mutations中存放方法

使用mutations中的方法

这是index.js中的一部分

export default new Vuex.Store({
    state:{
        model:""
    },
    mutations:{
        setModel(state,phoneModel){
			state.model = phoneModel
			console.log(state.model)
		}
    }
})

setModel是我自己定义的一个方法
参数要有两个,第一个都是state(应该是指向上面的state吧,刚学的我还很懵逼),第二个是自己定义的参数

在app.vue中使用

export default {
	onLaunch: function() {
		console.log('App Launch');
		let that = this;
		uni.getSystemInfo({
			success: function(res) {
				that.$store.commit('setModel',res.model)
			}
		});
	},
	onShow: function() {
		console.log('App Show');
	},
	onHide: function() {
		console.log('App Hide');
	}
};
</script>

使用这个方法只需要this.$store.commit('方法名',要传入的变量)
这里我传的是当前手机的型号

使用state中的值

使用非常简单
只需要this.$store.state.变量名
比如刚刚设好的model

this.$store.state.model
  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
uniapp,有几种方法可以实现全局变量使用。一种方法是通过在App.vue文件定义globalData,这样就可以在整个应用程序访问和修改这些全局变量。另一种方法使用vuex,通过在store定义state来管理全局变量。在mutations更新state的值,并且可以选择将这些变量存储在本地Local Storage,以便在H5刷新或者APP下次启动时自动赋值给state。这样可以避免在每个变量上都写一个对应的mutations步骤。\[2\]此外,还可以使用通用模块来实现全局变量的复用,将一些通用的变量方法或函数进行抽象,以便在整个应用程序进行复用,比如baseurl和通用的工具函数等等。\[1\]总之,uniapp提供了多种方法来实现全局变量使用,开发者可以根据自己的需求选择适合的方法。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [uniapp全局变量和全局函数的实现](https://blog.csdn.net/abs625/article/details/120992810)[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^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [uniapp全局变量的实现](https://blog.csdn.net/weixin_45788691/article/details/107221562)[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^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [uni-app全局变量的4种实现方式](https://blog.csdn.net/qq_40660283/article/details/130525140)[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^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值