欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue項(xiàng)目中定義全局變量、函數(shù)的幾種方法

 更新時(shí)間:2019年11月08日 08:27:05   作者:蛙哇  
這篇文章主要介紹了vue項(xiàng)目中定義全局變量、函數(shù)的幾種方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

在項(xiàng)目中,經(jīng)常會(huì)復(fù)用一些變量和函數(shù),比如用戶的登錄token,用戶信息等。這時(shí)將它們?cè)O(shè)為全局的就顯得很重要了,全局變量和全局函數(shù)之間有一些相通之處,它們其實(shí)很簡單,但是有些人可能還不太了解。簡單總結(jié)分享一波,希望對(duì)你有所幫助。

定義全局變量

原理:使用模塊(.js或.vue文件)來管理全局變量,最后使用export暴露出去 (最好導(dǎo)出的格式為對(duì)象,方便在其他地方調(diào)用),當(dāng)其它地方需要使用時(shí),用import導(dǎo)入該模塊

1、使用全局變量專用模塊,掛載到main.js文件上面

全局變量模塊Global.vue定義如下:

const token='12345678';
const userStatus=false;
export default {
  token, // 用戶token身份
  userStatus // 用戶登錄狀態(tài)
}

模塊里的變量用export暴露出去,當(dāng)其它地方需要使用時(shí),引入模塊便可。

使用全局變量:

import global from '../../components/Global'//引用模塊進(jìn)來
export default {
data () {
  return {
     token:global.token,//將全局變量賦值到data里面
    }
  }
}

2、全局變量模塊掛載到Vue.prototype上

Global.vue文件同上,在項(xiàng)目入口的main.js里配置:

import global from '../../components/Global'
Vue.prototype.GLOBAL = global

掛載之后,在需要引用全局變量的模塊處,不需再導(dǎo)入全局變量模塊,而是直接用this就可以引用了,如下:

export default {
 data () {
  return {
   token: this.GLOBAL.token,
  }
 }
}

方法一跟方法二的主要區(qū)別是,方法二全局只需要導(dǎo)入一次就可以,簡單方便。

3、使用vuex定義全局變量

Vuex是一個(gè)專為Vue.js應(yīng)用程序開發(fā)的狀態(tài)管理模式。它采用集中式存儲(chǔ)管理應(yīng)用的所有組件的狀態(tài)。因此可以存放著全局量。

// index.js文件里定義vuex
import state from './state'
export default new Vuex.Store({
 actions,
 getters,
 mutations,
 state,
})
// state.js里面存放全局變量,并且暴露出去
const state = {
 token:'12345678',
 language: 'en',
}

export default state

使用的時(shí)候,在需要引用全局變量的模塊處直接使用this.$store調(diào)用

export default {
  methods: {
   getInternation() {
    if (this.$store.state.language === 'en') {
     this.internation = 2
    } else if (this.$store.state.language === 'zh_CN') {
     this.internation = 1
    }
   }
  } 
}

因?yàn)閂uex有點(diǎn)繁瑣,有點(diǎn)殺雞用牛刀的感覺。因此認(rèn)為并沒有必要使用它。上面只是簡單的使用,如果想要具體了解使用方式,可以去查閱資料具體掌握。

定義全局函數(shù)

原理:在main.js里面通過Vue.prototype將函數(shù)掛載到Vue實(shí)例上面,通過this.函數(shù)名,來運(yùn)行函數(shù)。

1、在main.js文件直接定義方法

簡單的函數(shù)可以直接寫在main.js文件里定義。

// 將方法掛載到vue原型上
Vue.prototype.changeData = function (){
 alert('執(zhí)行成功');
}

使用的時(shí)候組件里直接調(diào)用。

//直接通過this運(yùn)行函數(shù),這里this是vue實(shí)例對(duì)象
this.changeData();

2、使用全局函數(shù)專用模塊,掛載到main.js上面

base.js文件,文件位置可以放在跟main.js同一級(jí),方便引用(這點(diǎn)可以依據(jù)個(gè)人習(xí)慣決定)。

exports.install = function (Vue, options) {
  Vue.prototype.changeData = function (){
    alert('執(zhí)行成功');
  };
};

main.js引入并使用。

import base from './base'
Vue.use(base);

所有的組件里就可以調(diào)用該函數(shù)。

this.changeData();

結(jié)語

以上是vue中全局變量和全局函數(shù)使用的全部內(nèi)容。希望總結(jié)的東西對(duì)你有所幫組。還不太了解的可以多看幾遍,大家加油?。?!也希望大家多多支持腳本之家。

相關(guān)文章

  • 關(guān)于vue-color-顏色選擇器插件

    關(guān)于vue-color-顏色選擇器插件

    這篇文章主要介紹了關(guān)于vue-color-顏色選擇器插件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue實(shí)現(xiàn)簡單的登錄彈出框

    vue實(shí)現(xiàn)簡單的登錄彈出框

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)簡單的登錄彈出框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • vue搜索和vue模糊搜索代碼實(shí)例

    vue搜索和vue模糊搜索代碼實(shí)例

    這篇文章主要介紹了vue搜索和vue模糊搜索,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • Vue生產(chǎn)和開發(fā)環(huán)境如何切換及過濾器的使用

    Vue生產(chǎn)和開發(fā)環(huán)境如何切換及過濾器的使用

    本文主要介紹了Vue生產(chǎn)、開發(fā)環(huán)境如何切換及過濾器的使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 用Axios Element實(shí)現(xiàn)全局的請(qǐng)求loading的方法

    用Axios Element實(shí)現(xiàn)全局的請(qǐng)求loading的方法

    本篇文章主要介紹了用Axios Element實(shí)現(xiàn)全局的請(qǐng)求loading的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-03-03
  • 詳解如何在 vue 項(xiàng)目里正確地引用 jquery 和 jquery-ui的插件

    詳解如何在 vue 項(xiàng)目里正確地引用 jquery 和 jquery-ui的插件

    本篇文章主要介紹了詳解如何在 vue 項(xiàng)目里正確地引用 jquery 和 jquery-ui的插件,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-06-06
  • vue 中使用 vxe-table 制作可編輯表格的使用過程

    vue 中使用 vxe-table 制作可編輯表格的使用過程

    這篇文章主要介紹了vue 中使用 vxe-table 制作可編輯表格的使用過程,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-08-08
  • vue模塊移動(dòng)組件的實(shí)現(xiàn)示例

    vue模塊移動(dòng)組件的實(shí)現(xiàn)示例

    這篇文章主要介紹了vue模塊移動(dòng)組件的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • 在 Typescript 中使用可被復(fù)用的 Vue Mixin功能

    在 Typescript 中使用可被復(fù)用的 Vue Mixin功能

    這篇文章主要介紹了在 Typescript 中使用可被復(fù)用的 Vue Mixin功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2018-04-04
  • vue中重定向redirect:‘/index‘,不顯示問題、跳轉(zhuǎn)出錯(cuò)的完美解決

    vue中重定向redirect:‘/index‘,不顯示問題、跳轉(zhuǎn)出錯(cuò)的完美解決

    這篇文章主要介紹了vue中重定向redirect:‘/index‘,不顯示問題、跳轉(zhuǎn)出錯(cuò)的完美解決方案,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2020-09-09

最新評(píng)論