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


Posted in HTML / CSS onNovember 17, 2021

需求

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

中间件实现原理

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

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

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

注意点

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

上代码

下面上一段我的判断各端的代码

class Addon {
  constructor () {
    let ua = window.navigator.userAgent.toLowerCase()
    if (/MPBank/.test(window.navigator.userAgent)) {
      // 招商行小程序
      
    } else if (ua.match(/MicroMessenger/i) == 'micromessenger') {
      // 大部分手机可采用此判断,是否是小程序,但有小部分华为等手机因为加载慢,这里会出现误判
      if (window.__wxjs_environment === 'miniprogram' || ua.match(/miniprogram/i) == 'miniprogram') {
        
      } else {
        
      }
    } else if (/AlipayClient/.test(window.navigator.userAgent)) {
      // 此处用ua和miniprogram判断,先查看兼容性,使用my.getEnv为异步,不适合此处
      if (ua.match(/miniprogram/i) == 'miniprogram' || ua.match(/webview/i) == 'webview') {
        // 支付宝小程序
        
      } else {
        // 支付宝
        
      }
    } else if (/xxxx-app/.test(window.navigator.userAgent)) {
      // app
      
    } else {
      // 其他处理(web和第三方渠道进入) 兜底
      
    }
}

export let addon = new Addon()

下面是一个简单的方法示例
ParentAddon.js

export default class ParentAddon {
     scan (data) {
         data.success('xxx')
     }
}

IosAppAddon.js

export default class IosAppAddon extends ParentAddon {
    scan (data) {
        window.scanCallback = data.success
        window.webkit.messageHandlers.scan.postMessage({
          callBack: 'scanCallback'
        })
     }
}

到此这篇关于Html5同时支持多端sdk的小技巧的文章就介绍到这了,更多相关Html5多端sdk内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

 
HTML / CSS 相关文章推荐
CSS3中的5个有趣的新技术
Apr 02 HTML / CSS
CSS图片翻转动画技术详解(IE也实现了)
Apr 03 HTML / CSS
CSS3圆角边框和边界图片效果实例
Jul 01 HTML / CSS
css3实现背景动态渐变效果
Dec 10 HTML / CSS
基于Html5实现的react拖拽排序组件示例
Aug 13 HTML / CSS
关于 HTML5 的七个传说小结
Apr 12 HTML / CSS
HTML5之SVG 2D入门4—笔画与填充
Jan 30 HTML / CSS
HTML5 Canvas自定义圆角矩形与虚线示例代码
Aug 02 HTML / CSS
详解html2canvas截图不能截取圆角图片的解决方案
Jan 30 HTML / CSS
HTML5 input新增type属性color颜色拾取器的实例代码
Aug 27 HTML / CSS
canvas像素点操作之视频绿幕抠图
Sep 11 HTML / CSS
css之clearfix的用法深入理解(必看篇)
May 21 HTML / CSS
使用canvas仿Echarts实现金字塔图的实例代码
CSS中妙用 drop-shadow 实现线条光影效果
仅仅使用 HTML/CSS 实现各类进度条的方式汇总
纯 CSS 自定义多行省略的问题(从原理到实现)
CSS作用域(样式分割)的使用汇总
使用CSS实现小三角边框原理解析
CSS实现切角+边框+投影+内容背景色渐变效果
You might like
php获取微信共享收货地址的方法
2017/12/21 PHP
PHP PDOStatement::errorInfo讲解
2019/01/31 PHP
Laravel 6 将新增为指定队列任务设置中间件的功能
2019/08/06 PHP
PHP sdk文档处理常用代码示例解析
2020/12/09 PHP
如何让您的中波更粗更长 - 中波框形天线制作
2021/03/10 无线电
零基础学JavaScript最新动画教程+iso光盘下载
2008/01/22 Javascript
基于mootools 1.3框架下的图片滑动效果代码
2011/04/22 Javascript
jQuery EasyUI API 中文文档 - NumberSpinner数值微调器使用介绍
2011/10/21 Javascript
15个常用的jquery代码片段
2015/12/19 Javascript
WebGL利用FBO完成立方体贴图效果完整实例(附demo源码下载)
2016/01/26 Javascript
js实现带农历和八字等信息的日历特效
2016/05/16 Javascript
Javascript实现前端简单的路由实例
2016/09/11 Javascript
bootstrap读书笔记之CSS组件(上)
2016/10/17 Javascript
值得分享的Bootstrap Table使用教程
2016/11/23 Javascript
React组件refs的使用详解
2018/02/09 Javascript
微信小程序制作表格的方法
2019/02/14 Javascript
vue-cli3.X快速创建项目的方法步骤
2019/11/14 Javascript
深入webpack打包原理及loader和plugin的实现
2020/05/06 Javascript
[02:42]DOTA2城市挑战赛收官在即 四强之争风起云涌
2018/06/05 DOTA
[02:28]PWL开团时刻DAY3——Ink Ice与DeMonsTer之间的勾心斗角
2020/11/03 DOTA
介绍Python中的__future__模块
2015/04/27 Python
详解Python中的日志模块logging
2015/06/19 Python
Django中的CBV和FBV示例介绍
2018/02/25 Python
解决在Python编辑器pycharm中程序run正常debug错误的问题
2019/01/17 Python
对python中矩阵相加函数sum()的使用详解
2019/01/28 Python
ZABBIX3.2使用python脚本实现监控报表的方法
2019/07/02 Python
python爬取盘搜的有效链接实现代码
2019/07/20 Python
Python 保持登录状态进行接口测试的方法示例
2019/08/06 Python
python英语单词测试小程序代码实例
2019/09/09 Python
python判断是空的实例分享
2020/07/06 Python
python lambda的使用详解
2021/02/26 Python
CSS3新属性transition-property transform box-shadow实例学习
2013/06/06 HTML / CSS
德国自行车商店:Tretwerk
2019/06/21 全球购物
科学发展观标语
2014/10/08 职场文书
2015社区六五普法工作总结
2015/04/21 职场文书
幼儿园教师辞职信
2019/06/21 职场文书