小程序公共方法封装(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

相关文章

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

C#中读取XML文件的四种常用方法

《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行