小程序公共方法封装(app.js 源码分享)

2024-09-05 02:38

本文主要是介绍小程序公共方法封装(app.js 源码分享),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

封装一个好的功能集(全局方法库),能更好的保证代码的一致性和工作的高效。

下面是小编经过几次小程序项目经验累计的原创功能集,能满足大部分功能需求。有其它需求望开发者们自行添加和修改

小编还有话说:

  1. request 请求方法未使用 ES6 中的 Promise。大部分情况下都可以不使用 Promise,毕竟真正的多次回调的情况还是少数的。有需求的可自行通过增加Promise来解决。
  2. getElementData 获取元素自定义属性方法是非常非常实用的,在小程序中多多使用 data-* 是非常有必要的。
  3. 请求数据作为最关键的方法,在文章的尾部有源码提供,请往下看哦!

app.js

/*** 小程序全局方法参考* 作者:helang* 邮箱:helang.love@qq.com* QQ:1846492969
**/App({globalData: {isIphoneX: false},onLaunch: function () {/* 将是否iphoneX 信息缓存到全局公众数据中 */this.globalData.isIphoneX = this.isIphoneX();},/* iphoneX兼容 */isIphoneX() {let mobile = wx.getSystemInfoSync();if (mobile.model.indexOf("iPhone X") >= 0) {return true;} else {return false;}},/* 常用正则表达式集 */regExps: {email: /^[0-9a-zA-Z_]+@[0-9a-zA-Z_]+[\.]{1}[0-9a-zA-Z]+[\.]?[0-9a-zA-Z]+$/,    //邮箱mobile: /^(?:1\d{2})-?\d{5}(\d{3}|\*{3})$/,    //手机号码qq: /^[1-9][0-9]{4,9}$/,    //QQbefitName: /^[a-z0-9A-Z\u4e00-\u9fa5]+$/,    //合适的用户名,中文,字母,数字befitPwd: /^[a-z0-9A-Z_]+$/,     //合适的用户名,字母,数字,下划线allNumber: /^[0-9]+.?[0-9]$/    //全部为数字},/*获取元素自定义属性-当前事件元素 */getElementData(el, name) {if (name) {return el.currentTarget.dataset[name];} else {return el.currentTarget.dataset;}},/*获取元素大小及位置 */getElementRect(select, callBack) {wx.createSelectorQuery().select(select).boundingClientRect(function (rect) {callBack && callBack(rect);}).exec();},/*信息提示 */showToast(title = "未知错误,请重试!", icon = "none", duration = 2000) {wx.showToast({title: title,icon: icon,duration: duration,mask: true});},/*加载提示 */showLoading(title = "正在加载") {wx.showLoading({title: title,mask: true});},/*请求地址*/requestUrl: "https://wxapi.xxx.com",/*发送请求 */request(param = {}, successFn, failFn) {wx.request({"url": this.requestUrl + param.url,"method": param.method || "POST","data": param.data || {},"success": (res) => {if (res.statusCode == 200) {successFn && successFn(res.data);} else {wx.hideLoading();this.showToast("请求失败,请重试!");}},"fail": () => {wx.hideLoading();if (failFn) {failFn();} else {this.showToast("网络错误!请重试!");}}});},/*上传文件地址*/uploadFileUrl: "https://imgupload.xxx.com",/* 上传文件*  files : 文件路径*/uploadFile(files, callFn) {wx.uploadFile({url: this.uploadFileUrl,filePath: files,name: 'file',formData: {	// 这里的数据一般都为固定的,请根据自己的业务需求修改"UserID": '用户ID',"Token": '用户令牌'},success: (res) => {if (res.statusCode == 200) {callFn && callFn(res.data);} else {wx.hideLoading();this.showToast("上传失败,请重试!");}},fail: () => {wx.hideLoading();this.showToast("上传失败,请重试!");}});},/* 获取上一页路由* 这个很重要,处理上一个路由栈*/getPrevPage() {const pages = getCurrentPages();const prevPage = pages[pages.length - 2];return prevPage;},/* 关闭当前页面 */closePage() {wx.navigateBack({delta: 1});},/*获取随机数*/getRandom(min, max) {return Math.floor(Math.random() * (max - min)) + min + 1;}
})

request 请求方法,使用示例

/* 获取到小程序全局唯一的 App 实例。* 建议在 pages/*.js 的头部引用,引用一次多次使用,避免滥用 getApp() 函数
*/
const app=getApp();/* 使用全局 request 请求方法 */
app.request({"url":'/list',      // 请求地址,必需的"method":"GET",     // 提交方式,默认POST,默认时可省略"data":{"a":"1"}    // 提交数据,默认undefined,不需要提交数据时可省略
},(res)=>{//请求成功的回调函数console.log(res);
},()=>{//请求失败的回调函数,不需要时可省略
})

作者:黄河爱浪 QQ:1846492969,邮箱:helang.love@qq.com

微信公众号:web-7258,本文原创,著作权归作者所有,转载请注明原链接及出处。

更多精彩文章,请扫下方二维码关注我的公众号

这篇关于小程序公共方法封装(app.js 源码分享)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1137736

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

MyBatis-Plus 中 nested() 与 and() 方法详解(最佳实践场景)

《MyBatis-Plus中nested()与and()方法详解(最佳实践场景)》在MyBatis-Plus的条件构造器中,nested()和and()都是用于构建复杂查询条件的关键方法,但... 目录MyBATis-Plus 中nested()与and()方法详解一、核心区别对比二、方法详解1.and()

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

golang中reflect包的常用方法

《golang中reflect包的常用方法》Go反射reflect包提供类型和值方法,用于获取类型信息、访问字段、调用方法等,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录reflect包方法总结类型 (Type) 方法值 (Value) 方法reflect包方法总结

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四