首頁 > web前端 > uni-app > uniapp如何修改全域變數

uniapp如何修改全域變數

coldplay.xixi
發布: 2020-12-15 16:22:44
原創
5835 人瀏覽過

uniapp修改全域變數的方法:1、在普通頁面取得全域變量,重新賦值;2、透過vue的狀態管理工具vuex管理全域變量,程式碼為【let str = contObj.str;】。

uniapp如何修改全域變數

本教學操作環境:windows7系統、uni-app2.5.1版本,此方法適用於所有品牌電腦。

推薦(免費):uni-app開發教學

uniapp修改全域變數的方法:

一、引用公用common.js(1、可在頁面中直接引入common.js 2、在main.js中引用並掛載(這裡是第二種))

export default {
    memberObj:{
        name:'初始姓名',
    },
    setMemberObj(data){
        this.memberObj = Object.assign({},this.memberObj,data) 
    }
}
登入後複製

(1)、在全域main. js中引用

import Vue from 'vue'
import App from './App'
import member from './common/common.js'
import store from './store'
Vue.config.productionTip = false
Vue.prototype.$store = store
Vue.prototype.$member = member;
Vue.prototype.$enName = 'ming';
App.mpType = 'app'
const app = new Vue({
    store,
    ...App
})
app.$mount()
登入後複製

在普通頁面取得全域變量,重新賦值

onShow:function(){
    //获取全局设置的变量
    this.memberData = this.$member.memberObj;
    console.log(this.memberData);
    //输出值{name:'初始姓名'}
},
methods: {
  bindLogin() {
    let that = this;
    let obj = {
        name:'爱尚',
        sex:'男'
    }
    that.$member.setMemberObj(obj);
  },
}
//再次在别的页面调用时内容已发生变化
console.log(this.$member.memberObj)
//{name:'爱尚',sex:'男'}
登入後複製

二、透過vue的狀態管理工具vuex管理全域變數

1、创建store文件,store.js
import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
const store = new Vuex.Store({
    state: {
        memberData:'',
        initName:''
    },
    mutations: {
        copy(state,cont){
            //单一的改变某一个变量
            console.log(state)
            console.log(cont)
            state.memberData = cont;
        },
        change(state,contObj){
            //通过传入的变量去改变对应的全局变量
            let str = contObj.str;
            let cont = contObj.cont;
            state[str] = cont;
        },
    },
    actions:{
        copeFun:function(context,mData){
            context.commit('copy',mData)
        },
        changeFun:function(context,obj){
            context.commit('change',obj)
        }
    }
})
export default store
登入後複製

1、在main. js中引入store.js

import Vue from 'vue'
import App from './App'
import store from './store';
Vue.config.productionTip = false;
Vue.prototype.$store = store;
App.mpType = 'app';
const app = new Vue({
    store,
    ...App
})
app.$mount()
登入後複製

2、頁面中取得需要使用的全域變數

(1)、直接透過全域掛載的那種方式去取得(定義在計算屬性中是為了方便即時的監聽變數重新賦值)

1、直接通过全局挂载的那种方式去获取
computed:{
   memberData:function(){
      return this.$store.state.memberData;
   },
},
登入後複製

(2)、透過頁面中引入vuex去獲取

import {mapState,mapMutations} from "vuex";
computed:{
  //正常写法
    ...mapState({
        memberData:state => state.memberData,
        initName:state => state.initName,
    })
  //当变量名一致时(简写)
  //...mapState(['initName','memberData'])
},
登入後複製

3、重新賦值vuex中的全域變數

methods:{
    //单一方法改变指定的变量
  changeMember:function(){
    let mem = {
        name:'爱尚丽明',
        age:'28'
    }
    this.$store.dispatch('copeFun',mem)
    },      
       //通过传入要改的变量名进行改变变量
    changeMemberPub:function(){
      let memberData = {
        name:'爱尚',
        age:25
    }
    let $obj = {}
    $obj.cont = memberData ;
    $obj.str = 'memberData'
    this.$store.dispatch('changeFun',$obj)
   }       
}
登入後複製

相關免費學習推薦:php程式設計(影片)

以上是uniapp如何修改全域變數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板