设为首页收藏本站

安徽论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 8051|回复: 0

Html5同时支持多端sdk的小技巧

[复制链接]

85

主题

0

回帖

267

积分

中级会员

Rank: 3Rank: 3

积分
267
发表于 2022-3-26 10:58:28 | 显示全部楼层 |阅读模式
网站内容均来自网络,本站只提供信息平台,如有侵权请联系删除,谢谢!
需求

在实际项目中,我们通常会需要做一些跨多平台的页面。比如说一个活动页面,需要在微信小程序里展示,也需要在自家公司的app里面展示,还需要在支付宝等平台里面展示。这时候一个h5就是很符合你的需要了。如果这个时候需求再复杂一些,比如说在这个活动页面需要调些扫码功能,或者需要调起支付功能,等原生方法调用的需求,那么这个时候你需要一个中间件,来处理不同端的原生方法。
中间件实现原理

原理很简单,我们在抽象出来一个类,在这类里面,我们将需要用到原生的方法进行实现,其他终端对这个类进行继承并重写所有的方法。

偷懒的话,可以不要pc调试类,直接在父类实现pc调试类里的所有方法。
实现完了,接下来就是调用了,如果在每个页面都判断终端是哪端就太麻烦了,并且也没有必要把每端的中间件代码都加载进来(可以使用require进行异步加载)。在页面加载的过程中,根据判断创建对应终端的中间件对象addon,并将这个中间件对象挂载到window上面,在使用时候就可以直接使用window.addon.scan()
注意点

微信、支付宝都有其对应的判断方法,但自家app的判断, 需要原生开发在userAgent里面添加标识(这个不复杂,原生都知道怎么加,不知道的请问度娘)
另外ios webview不再支持同步方法,建议所有的方法采用异步调用方式, 参考示例。
上代码

下面上一段我的判断各端的代码
  1. class Addon {
  2.   constructor () {
  3.     let ua = window.navigator.userAgent.toLowerCase()
  4.     if (/MPBank/.test(window.navigator.userAgent)) {
  5.       // 招商行小程序
  6.       
  7.     } else if (ua.match(/MicroMessenger/i) == 'micromessenger') {
  8.       // 大部分手机可采用此判断,是否是小程序,但有小部分华为等手机因为加载慢,这里会出现误判
  9.       if (window.__wxjs_environment === 'miniprogram' || ua.match(/miniprogram/i) == 'miniprogram') {
  10.         
  11.       } else {
  12.         
  13.       }
  14.     } else if (/AlipayClient/.test(window.navigator.userAgent)) {
  15.       // 此处用ua和miniprogram判断,先查看兼容性,使用my.getEnv为异步,不适合此处
  16.       if (ua.match(/miniprogram/i) == 'miniprogram' || ua.match(/webview/i) == 'webview') {
  17.         // 支付宝小程序
  18.         
  19.       } else {
  20.         // 支付宝
  21.         
  22.       }
  23.     } else if (/xxxx-app/.test(window.navigator.userAgent)) {
  24.       // app
  25.       
  26.     } else {
  27.       // 其他处理(web和第三方渠道进入) 兜底
  28.       
  29.     }
  30. }

  31. export let addon = new Addon()
复制代码
下面是一个简单的方法示例
ParentAddon.js
  1. export default class ParentAddon {
  2.      scan (data) {
  3.          data.success('xxx')
  4.      }
  5. }
复制代码
IosAppAddon.js
  1. export default class IosAppAddon extends ParentAddon {
  2.     scan (data) {
  3.         window.scanCallback = data.success
  4.         window.webkit.messageHandlers.scan.postMessage({
  5.           callBack: 'scanCallback'
  6.         })
  7.      }
  8. }
复制代码
到此这篇关于Html5同时支持多端sdk的小技巧的文章就介绍到这了,更多相关Html5多端sdk内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!
                                                                                               
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
免责声明
1. 本论坛所提供的信息均来自网络,本网站只提供平台服务,所有账号发表的言论与本网站无关。
2. 其他单位或个人在使用、转载或引用本文时,必须事先获得该帖子作者和本人的同意。
3. 本帖部分内容转载自其他媒体,但并不代表本人赞同其观点和对其真实性负责。
4. 如有侵权,请立即联系,本网站将及时删除相关内容。
懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表