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


一、全局引入文件

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) } ) },

總結 實例
common.vue文件,項目中的公共,或者全局文件

vue-resource需要先配置一下 main.js

// 配置使用formDate
Vue.http.options.emulateHTTP = true Vue.http.options.emulateJSON = true
<script type="text/javascript"> // 定義一些公共的屬性和方法 const httpUrl = 'http://39.105.17.99:8080/' function promiseFun (url, params) { return new Promise((resolve, reject) => { this.$http.post(this.globalHttpUrl + url, params).then( (res) => { resolve(res.json()) }, (err) => { reject(err.json()) } ) }) } // 暴露出這些屬性和方法 export default { httpUrl, promiseFun } </script>

使用

 
export default { data () { return { username: '', password: '', globalHttpUrl: global.httpUrl, promiseFun: global.promiseFun } }, methods: { loginInFun () { localStorage.setItem('userId', '00001') let params = { telphone: this.username, password: this.password } this.promiseFun('itArtison/user/login', params).then( (res) => { console.log(res) this.$Message.info(res.message) // 登錄成功過以后,這里從初session // 先將對象轉換為json字符串 localStorage.setItem('userInfo', JSON.stringify(res.data)) if (res.code === '0000') { this.$router.push({'name': 'Home'}) } }, (err) => { console.log(err) this.$Message.info(err.message) } ) } }


免責聲明!

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



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