vue定義全局變量和全局方法


轉載

原文地址:https://segmentfault.com/a/1190000015842187

一、全局引入文件

1、先定義共用組件 common.vue

<script type="text/javascript">
    // 定義一些公共的屬性和方法
    const httpUrl = 'http://39.105.17.99:8080/'
    function commonFun() {
        console.log("公共方法")
    }
    // 暴露出這些屬性和方法
    export default {
        httpUrl,
        commonFun
    }
</script>

2、在需要使用的地方導入

<script>
// 導入共用組件
import global from './common.vue'
export default {
  data () {
    return {
      username: '',
      password: '',
      // 賦值使用
      globalHttpUrl: global.httpUrl
    }
  },

3、使用

<template>
    {{globalHttpUrl}}
</template>

二、main.js中引入全局變量和方法

1、定義共用組件同上
2、main.js中引入並復制給vue

// 導入共用組件
import global from './common.vue'
Vue.prototype.COMMON = global

3、使用

export default {
  data () {
    return {
      username: '',
      password: '',
      // 賦值使用, 可以使用this變量來訪問
      globalHttpUrl: this.COMMON.httpUrl
    }
  },

三、定義common.js文件,直接在main.js中引入,直接使用

1、common.js 這里注意 Vue.http 組件中使用 this.$http

import Vue from 'vue'
import VueResource from 'vue-resource'
Vue.use(VueResource)
const httpUrl = 'http://39.105.17.99:8080/'
function httpGet (url, params) {
  return new Promise((resolve, reject) => {
    Vue.http.get(this.httpUrl + url, params).then(
      (res) => {
        resolve(res.json())
      },
      (err) => {
        reject(err.json())
      }
    )
  })
}

function httpPost (url, params) {
  return new Promise((resolve, reject) => {
    Vue.http.post(this.httpUrl + url, params).then(
      (res) => {
        resolve(res.json())
      },
      (err) => {
        reject(err.json())
      }
    )
  })
}
export default {
  httpUrl,
  httpGet,
  httpPost
}

2、main.js

import global from './common/common'
Vue.prototype.GLOBAL = global

3、使用

<template>
  {{GLOBAL.httpUrl}}

--------------------------------------------

 created () {
    this.GLOBAL.httpGet('/home/list', {'name': 'zxc', 'password': '123'}).then(
    (res) => {
        console.log(res)
     }
    )
  },

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM