首頁 >web前端 >js教程 >如何在vue2中設定全域變數? (詳細教學)

如何在vue2中設定全域變數? (詳細教學)

亚连
亚连原創
2018-05-31 15:24:563949瀏覽

下面我就為大家分享一篇vue2 全域變數的設定方法,具有很好的參考價值,希望對大家有幫助。

最近在學習VUE.js 中間涉及到JS全域變量,與其說是VUE的全域變量,不如說是模組化JS開發的全域變數。

1、全域變數專用模組

就是要以特定模組來組織管理這些全域量,需要引用的地方導入該模組便好。

全域變數專用模組 Global.vue

<script type="text/javascript">
const colorList = [
 &#39;#F9F900&#39;,
 &#39;#6FB7B7&#39;,
 &#39;#9999CC&#39;,
 &#39;#B766AD&#39;,
 &#39;#B87070&#39;,
 &#39;#FF8F59&#39;,
 &#39;#FFAF60&#39;,
 &#39;#FFDC35&#39;,
 &#39;#FFFF37&#39;,
 &#39;#B7FF4A&#39;,
 &#39;#28FF28&#39;,
 &#39;#1AFD9C&#39;,
 &#39;#00FFFF&#39;,
 &#39;#2894FF&#39;,
 &#39;#6A6AFF&#39;,
 &#39;#BE77FF&#39;,
 &#39;#FF77FF&#39;,
 &#39;#FF79BC&#39;,
 &#39;#FF2D2D&#39;,
 &#39;#ADADAD&#39;
]
const colorListLength = 20
function getRandColor () {
 var tem = Math.round(Math.random() * colorListLength)
 return colorList[tem]
}
export default
{
 colorList,
 colorListLength,
 getRandColor
}
</script>

模組裡的變數以export 暴露出去,當其它地方需要使用時,引入模組global便可。

需要使用全域變數的模組 html5.vue

<template>
 <ul>
  <template v-for="item in mainList">
   <p class="projectItem" :style="&#39;box-shadow:1px 1px 10px &#39;+ getColor()">
     <router-link :to="&#39;project/&#39;+item.id">
      ![](item.img)
      <span>{{item.title}}</span>
     </router-link>
   </p>
  </template>
 </ul>
</template>
<script type="text/javascript">
import global_ from &#39;components/tool/Global&#39;
export default {
 data () {
  return {
   getColor: global_.getRandColor,
   mainList: [
    {
     id: 1,
     img: require(&#39;../../assets/rankIcon.png&#39;),
     title: &#39;登录界面&#39;
    },
    {
     id: 2,
     img: require(&#39;../../assets/rankIndex.png&#39;),
     title: &#39;主页&#39;
    }
   ]
  }
 }
}
</script>
<style scoped type="text/css">
.projectItem
{
 margin: 5px;
 width: 200px;
 height: 120px;
 /*border:1px soild;*/
 box-shadow: 1px 1px 10px;
}
.projectItem a
{
 min-width: 200px;
}
.projectItem a span
{
 text-align: center;
 display: block;
}
</style>

2、全域變數模組掛載到Vue.prototype 裡。

Global.js同上,在程式入口的main.js裡加上下面程式碼

import global_ from &#39;./components/tool/Global&#39;
Vue.prototype.GLOBAL = global_

掛載之後,在需要引用全域量的模組處,不需要再導入全域量模組,直接用this就可以引用了,如下:

<script type="text/javascript">
export default {
 data () {
  return {
   getColor: this.GLOBAL.getRandColor,
   mainList: [
    {
     id: 1,
     img: require(&#39;../../assets/rankIcon.png&#39;),
     title: &#39;登录界面&#39;
    },
    {
     id: 2,
     img: require(&#39;../../assets/rankIndex.png&#39;),
     title: &#39;主页&#39;
    }
   ]
  }
 }
}
</script>

#3、使用VUEX

Vuex 是專為Vue .js 應用程式開發的狀態管理模式。它採用集中式儲存管理應用的所有元件的狀態。因此可以存放著全局量。因Vuex有點繁瑣,有點殺雞用牛刀的感覺。認為並沒有必要。

上面是我整理給大家的,希望今後對大家有幫助。

相關文章:

Vue的路由動態重定向和導航守衛實例

JS實作為動態建立的元素新增事件操作範例

對vue裡函數的呼叫順序介紹

以上是如何在vue2中設定全域變數? (詳細教學)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn