微信小程序全局变量功能与用法详解


Posted in Javascript onJanuary 22, 2019

本文实例讲述了微信小程序全局变量功能与用法。分享给大家供大家参考,具体如下:

全局变量的作用

在微信小程序开发中,会遇到一个很实际的应用场景,就是一个变量会在多个页面进行使用。

例如:

1. 在微信小程序开发中使用高德地图的微信小程序开发,其中key值就需要在多个页面使用;

2. 在微信小程序开发电商平台时同样,比如客服电话,就需要在多个页面使用。

在以上两种类似的场景中,开发者就需要使用全局变量,当然也有开发者说不能每个page页面都定义一个?如果客服电话改变,如果客服要求采用他的高德key,这个时候只需要修改全局,就能进行整个小程序的修改,如果每个page一个变量,将会在修改中花费大量的时间做低效的工作。所以可以看出全局变量在这里的作用就是提高开发效率!

如何定义全局变量

方法一:用APP定义全局变量

在app.js中的APP({})传入对象中定义一个全局属性globalData,作为保存全局变量的对象。

示例代码:

声明变量进行引入!

// 引入高德地图js
const amap = require('./src/js/amap-wx.js');
// 引入接口js
const urlList = require('./src/js/config.js');
// 引入wetoast插件js
const { WeToast } = require('./src/wetoast/wetoast.js');
// 全局变量高德地图key
const key = 'c290b7e016c85e8f279b2f80018c';
// 全局变量服务电话
const phone = '400-007-859';

进行全局变量的赋值!

App({
 globalData: {//全局变量
  amap: amap,
  key: key,
  phone: phone,
  urlList: urlList.urlList
 }
})

方法一全局变量的使用:

//在page页面引入app,同时声明变量,获得所需要的全局变量
const app = getApp();
const urlList = app.globalData.urlList;

方法二:用引入js的方法定义全局变量

在公用js文件夹中创建一个保存全局变量的js文件

实例:我在公用文件夹src下的js文件夹中创建的三个保存全局变量的文件:base64.js、config.js、data.js

微信小程序全局变量功能与用法详解

这三个文件作用:

1. base64.js保存背景图标转化的base64码
2. config.js保存request请求数据的路径
3. data.js 保存初次开发的模拟数据

示例代码:

let basePath = 'https://xxxxx.com';
let urlList = {
  goodsListUrl: basePath + '/goodsList',
  shopCartUrl: basePath + '/shopCart',
  ...
}
module.exports = {
 urlList: urlList
}

使用方法:

// 引入接口js
const urlList = require('./src/js/config.js');
wx.request({
  url: urlList.urlList.goodsListUrl,
  data: {},
  success: res => {}
})

总结

其实两种方法都可以定义全局变量,那么在什么时候采用哪一种方法?我个人建议,在像高德地图的key值这种只需要单独定义的,可以采用方法一,方便、简洁、不用单独创建文件。在请求地址这种批量全局变量的定义时,采用方法二,有利于后期的查找和修改。两种方法结合,更有利于开发!

希望本文所述对大家微信小程序开发有所帮助。

Javascript 相关文章推荐
脚本吧 - 幻宇工作室用到js,超强推荐expand.js
Dec 23 Javascript
javascript之典型高阶函数应用介绍
Jan 10 Javascript
jquery分页对象使用示例
Apr 01 Javascript
EasyUI中datagrid在ie下reload失败解决方案
Mar 09 Javascript
js实现带缓冲效果的仿QQ面板折叠菜单代码
Sep 06 Javascript
seajs加载jquery时提示$ is not a function该怎么解决
Oct 23 Javascript
基于JavaScript将表单序列化类型的数据转化成对象的处理(允许对象中包含对象)
Dec 28 Javascript
JavaScript中日常收集常见的10种错误(推荐)
Jan 08 Javascript
vue刷新和tab切换实例
Feb 11 Javascript
vue脚手架及vue-router基本使用
Apr 09 Javascript
vue + typescript + video.js实现 流媒体播放 视频监控功能
Jul 07 Javascript
javascript中this的用法实践分析
Jul 29 Javascript
微信小程序使用map组件实现路线规划功能示例
Jan 22 #Javascript
JavaScript JMap类定义与使用方法示例
Jan 22 #Javascript
vue2.0 如何在hash模式下实现微信分享
Jan 22 #Javascript
JavaScript继承与聚合实例详解
Jan 22 #Javascript
JavaScript格式化json和xml的方法示例
Jan 22 #Javascript
基于vue的验证码组件的示例代码
Jan 22 #Javascript
JavaScript中的"=、==、==="区别讲解
Jan 22 #Javascript
You might like
php实现mysql数据库备份类
2008/03/20 PHP
PHP中使用foreach和引用导致程序BUG的问题介绍
2012/09/05 PHP
解析PHP生成静态html文件的三种方法
2013/06/18 PHP
使用PHP导出Word文档的原理和实例
2013/10/21 PHP
解决php-fpm.service not found问题的办法
2017/06/06 PHP
PHP编程快速实现数组去重的方法详解
2017/07/22 PHP
php使用 readfile() 函数设置文件大小大小的方法
2017/08/11 PHP
PHP实现超简单的SSL加密解密、验证及签名的方法示例
2017/08/28 PHP
ThinkPHP框架整合微信支付之Native 扫码支付模式一图文详解
2019/04/09 PHP
读jQuery之五(取DOM元素)
2011/06/20 Javascript
jquery 循环显示div的示例代码
2013/10/18 Javascript
jquery delay()介绍及使用指南
2014/09/02 Javascript
jQuery实现DIV层淡入淡出拖动特效的方法
2015/02/13 Javascript
javascript生成不重复的随机数
2015/07/17 Javascript
jQuery xml字符串的解析、读取及查找方法
2016/03/01 Javascript
js实现获取两个日期之间所有日期的方法
2016/06/17 Javascript
JavaScript实现图片懒加载(Lazyload)
2016/11/28 Javascript
快速实现JS图片懒加载(可视区域加载)示例代码
2017/01/04 Javascript
老生常谈jquery id选择器和class选择器的区别
2017/02/12 Javascript
AngularJS使用ui-route实现多层嵌套路由的示例
2018/01/10 Javascript
Javascript 之封装(Package)
2018/09/14 Javascript
微信小程序发布新版本时自动提示用户更新的方法
2019/06/07 Javascript
构建大型 Vue.js 项目的10条建议(小结)
2019/11/14 Javascript
[26:24]完美副总裁、DOTA2负责人蔡玮专访:电竞如人生
2014/09/11 DOTA
[02:20]DOTA2亚洲邀请赛 IG战队出场宣传片
2015/02/07 DOTA
学习python (1)
2006/10/31 Python
python发送邮件的实例代码(支持html、图片、附件)
2013/03/04 Python
python3.6利用pyinstall打包py为exe的操作实例
2018/10/31 Python
记一次python 内存泄漏问题及解决过程
2018/11/29 Python
Python Django切换MySQL数据库实例详解
2019/07/16 Python
Python实现发票自动校核微信机器人的方法
2020/05/22 Python
Senreve官网:美国旧金山的奢侈手袋品牌
2019/03/21 全球购物
2014年幼儿园教师工作总结
2014/11/08 职场文书
2015秋季开学典礼新闻稿
2015/07/17 职场文书
《少年闰土》教学反思
2016/02/18 职场文书
golang slice元素去重操作
2021/04/30 Golang