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 相关文章推荐
使用HTML5和CSS3表单验证功能
May 05 HTML / CSS
CSS3 中的@keyframes介绍
Sep 02 HTML / CSS
纯css3实现图片翻牌特效
Mar 10 HTML / CSS
CSS中垂直居中的简单实现方法
Jul 06 HTML / CSS
css3给背景图片加颜色遮罩的方法
Nov 05 HTML / CSS
css3媒体查询中device-width和width的区别详解
Mar 27 HTML / CSS
分享全球十款超强HTML5开发工具
May 14 HTML / CSS
HTML 5.1来了 9月份正式发布 更新内容预览
Apr 26 HTML / CSS
HTML5图片层叠的实现示例
Jul 07 HTML / CSS
HTML5 video进入全屏和退出全屏的实现方法
Jul 28 HTML / CSS
Canvas波浪花环的示例代码
Aug 21 HTML / CSS
CSS3实现的水平标题菜单
Apr 14 HTML / CSS
使用canvas仿Echarts实现金字塔图的实例代码
CSS中妙用 drop-shadow 实现线条光影效果
仅仅使用 HTML/CSS 实现各类进度条的方式汇总
纯 CSS 自定义多行省略的问题(从原理到实现)
CSS作用域(样式分割)的使用汇总
使用CSS实现小三角边框原理解析
CSS实现切角+边框+投影+内容背景色渐变效果
You might like
使用PHP获取汉字的拼音(全部与首字母)
2013/06/27 PHP
PHP ignore_user_abort函数详细介绍和使用实例
2014/07/15 PHP
php使用goto实现自动重启swoole、reactphp、workerman服务的代码
2020/04/13 PHP
js对列表中第一个值处理与jsp页面对列表中第一个值处理的区别详解
2013/11/05 Javascript
JS将表单导出成EXCEL的实例代码
2013/11/11 Javascript
checkbox选中与未选中判断示例
2014/08/04 Javascript
使用javascript实现监控视频播放并打印日志
2015/01/05 Javascript
js实现从中间开始往上下展开网页窗口的方法
2015/03/02 Javascript
Bootstrap表单组件教程详解
2016/04/26 Javascript
JavaScript函数节流概念与用法实例详解
2016/06/20 Javascript
Mvc提交表单的四种方法全程详解
2016/08/10 Javascript
jQuery动态创建元素以及追加节点的实现方法
2016/10/20 Javascript
jQuery实现最简单实用的分秒倒计时
2017/02/05 Javascript
canvas绘图不清晰的解决方案
2017/02/28 Javascript
ES6入门教程之let和const命令详解
2017/05/17 Javascript
vue非父子组件通信问题及解决方法
2018/06/11 Javascript
vue-cli系列之vue-cli-service整体架构浅析
2019/01/14 Javascript
React学习之受控组件与数据共享实例分析
2020/01/06 Javascript
Element-ui el-tree新增和删除节点后如何刷新tree的实例
2020/08/31 Javascript
python条件和循环的使用方法
2013/11/01 Python
在Python中处理XML的教程
2015/04/29 Python
Python中字典和集合学习小结
2017/07/07 Python
django文档学习之applications使用详解
2018/01/29 Python
python删除过期log文件操作实例解析
2018/01/31 Python
用python处理MS Word的实例讲解
2018/05/08 Python
Python3实现腾讯云OCR识别
2018/11/27 Python
tensorflow 固定部分参数训练,只训练部分参数的实例
2020/01/20 Python
pycharm 设置项目的根目录教程
2020/02/12 Python
Django DRF路由与扩展功能的实现
2020/06/03 Python
Html5+JS实现手机摇一摇功能
2015/04/24 HTML / CSS
微信小程序“圣诞帽”的实现思路详解
2017/12/28 HTML / CSS
State Cashmere官网:半零售价可持续蒙古羊绒
2020/02/26 全球购物
护士自荐信
2013/10/25 职场文书
学校青年志愿者活动总结
2015/05/06 职场文书
2015年干部教育培训工作总结
2015/05/15 职场文书
医院见习总结
2015/06/24 职场文书