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

相关文章

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

判断PyTorch是GPU版还是CPU版的方法小结

《判断PyTorch是GPU版还是CPU版的方法小结》PyTorch作为当前最流行的深度学习框架之一,支持在CPU和GPU(NVIDIACUDA)上运行,所以对于深度学习开发者来说,正确识别PyTor... 目录前言为什么需要区分GPU和CPU版本?性能差异硬件要求如何检查PyTorch版本?方法1:使用命

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll

Java中的工具类命名方法

《Java中的工具类命名方法》:本文主要介绍Java中的工具类究竟如何命名,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java中的工具类究竟如何命名?先来几个例子几种命名方式的比较到底如何命名 ?总结Java中的工具类究竟如何命名?先来几个例子JD

Spring Security自定义身份认证的实现方法

《SpringSecurity自定义身份认证的实现方法》:本文主要介绍SpringSecurity自定义身份认证的实现方法,下面对SpringSecurity的这三种自定义身份认证进行详细讲解,... 目录1.内存身份认证(1)创建配置类(2)验证内存身份认证2.JDBC身份认证(1)数据准备 (2)配置依

python获取网页表格的多种方法汇总

《python获取网页表格的多种方法汇总》我们在网页上看到很多的表格,如果要获取里面的数据或者转化成其他格式,就需要将表格获取下来并进行整理,在Python中,获取网页表格的方法有多种,下面就跟随小编... 目录1. 使用Pandas的read_html2. 使用BeautifulSoup和pandas3.

Spring 中的循环引用问题解决方法

《Spring中的循环引用问题解决方法》:本文主要介绍Spring中的循环引用问题解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录什么是循环引用?循环依赖三级缓存解决循环依赖二级缓存三级缓存本章来聊聊Spring 中的循环引用问题该如何解决。这里聊

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas统计每行数据中的空值的方法示例

《Pandas统计每行数据中的空值的方法示例》处理缺失数据(NaN值)是一个非常常见的问题,本文主要介绍了Pandas统计每行数据中的空值的方法示例,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是空值?为什么要统计空值?准备工作创建示例数据统计每行空值数量进一步分析www.chinasem.cn处