uni-app 是一个使用 Vue.js 开发所有前端应用的框架,开发者编写一套代码,可发布到  iOS、Android、H5、以及各种小程序(微信/支付宝/百度/头条/ QQ /钉钉)等多个平台。

1. 公用模块

定义一个专用的模块,用来组织和管理这些全局的变量,在需要的页面引入。

注意这种方式只支持多个 vue 页面或多个 nvue 页面之间公用,vue 和 nvue 之间不公用。

示例如下:
在 uni-app 项目根目录下创建 common 目录,然后在 common 目录下新建 helper.js 用于定义公用的方法。

const websiteUrl = 'http://uniapp.dcloud.io'
const now = Date.now || function () { 
    return new Date().getTime(); 
}; 
const isArray = Array.isArray || function (obj) { 
    return obj instanceof Array; 
}; 
export default 
    websiteUrl, 
    now, 
    isArray 
}

接下来在 pages/index/index.vue 中引用该模块

<script> 
    import helper from '../../common/helper.js'
    export default 
        data() { 
            return {}; 
        }, 
        onLoad(){ 
            console.log('now:' + helper.now()); 
        }, 
        methods: { 
        
    
</script>

这种方式维护起来比较方便,但是缺点就是每次都需要引入。

2. 挂载 Vue.prototype

将一些使用频率较高的常量或者方法,直接扩展到 Vue.prototype 上,每个 Vue 对象都会“继承”下来。

注意这种方式只支持 vue 页面

示例如下:
在 main.js 中挂载属性/方法

Vue.prototype.websiteUrl = 'http://uniapp.dcloud.io'
Vue.prototype.now = Date.now || function () { 
    return new Date().getTime(); 
}; 
Vue.prototype.isArray = Array.isArray || function (obj) { 
    return obj instanceof Array; 
};

然后在 pages/index/index.vue 中调用

<script> 
    export default 
        data() { 
            return {}; 
        }, 
        onLoad(){ 
            console.log('now:' this.now()); 
        }, 
        methods: { 
        
    
</script>

这种方式,只需要在 main.js 中定义好即可在每个页面中直接调用。

Tips

  • 每个页面中不要在出现重复的属性或方法名。
  • 建议在 Vue.prototype 上挂载的属性或方法,可以加一个统一的前缀。比如 $url、global_url 这样,在阅读代码时也容易与当前页面的内容区分开。

3. globalData

小程序中有个 globalData 概念,可以在 App 上声明全局变量。 Vue 之前是没有这类概念的,但 uni-app 引入了globalData 概念,并且在包括 H5、App 等平台都实现了。
在 App.vue 可以定义 globalData ,也可以使用 API 读写这个值。

globalData 支持 vue 和 nvue 共享数据。

globalData 是一种比较简单的全局变量使用方式。

定义:App.vue

<script> 
    export default 
        globalData: { 
            text: 'text'
        }, 
        onLaunch: function() { 
            console.log('App Launch'
        }, 
        onShow: function() { 
            console.log('App Show'
        }, 
        onHide: function() { 
            console.log('App Hide'
        
    
</script> 
<style> 
    /*每个页面公共css */
</style>

js 中操作 globalData 的方式如下:

赋值:getApp().globalData.text = 'test'

取值:console.log(getApp().globalData.text) // 'test'

如果需要把 globalData 的数据绑定到页面上,可在页面的 onshow 声明周期里进行变量重赋值。HBuilderX 2.0.3 起,nvue 页面在 uni-app 编译模式下,也支持 onshow。

参考链接:

  1.  https://ask.dcloud.net.cn/article/id-35021