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 选择器 基本选择器介绍
Jan 21 HTML / CSS
纯HTML+CSS3制作导航菜单(附源码)
Apr 24 HTML / CSS
纯CSS3实现的8种Loading动画效果
Jul 05 HTML / CSS
css3实例教程 一款纯css3实现的环形导航菜单
Oct 20 HTML / CSS
CSS3 实现倒计时效果
Nov 25 HTML / CSS
HTML5新控件之日期和时间选择输入的实现代码
Sep 13 HTML / CSS
使用HTML5的Canvas绘制曲线的简单方法
Sep 08 HTML / CSS
解决canvas转base64/jpeg时透明区域变成黑色背景的方法
Oct 23 HTML / CSS
常用的HTML5列表标签
Jun 20 HTML / CSS
canvas 如何绘制线段的实现方法
Jul 12 HTML / CSS
video.js支持m3u8格式直播的实现示例
May 20 HTML / CSS
html form表单基础入门案例讲解
Jul 15 HTML / CSS
使用canvas仿Echarts实现金字塔图的实例代码
CSS中妙用 drop-shadow 实现线条光影效果
仅仅使用 HTML/CSS 实现各类进度条的方式汇总
纯 CSS 自定义多行省略的问题(从原理到实现)
CSS作用域(样式分割)的使用汇总
使用CSS实现小三角边框原理解析
CSS实现切角+边框+投影+内容背景色渐变效果
You might like
用ADODB来让PHP操作ACCESS数据库的方法
2006/12/31 PHP
PHP加速 eAccelerator配置和使用指南
2009/06/05 PHP
PHP用mb_string函数库处理与windows相关中文字符及Win环境下开启PHP Mb_String方法
2015/11/11 PHP
Yii2下session跨域名共存的解决方案
2017/02/04 PHP
php usort 使用用户自定义的比较函数对二维数组中的值进行排序
2017/05/02 PHP
php判断电子邮件是否正确方法
2018/12/04 PHP
JQuery判断子iframe何时加载完成解决方案
2013/08/20 Javascript
使用javascript实现Iframe自适应高度
2014/12/24 Javascript
JavaScript中通过prototype属性共享属性和方法的技巧实例
2015/03/13 Javascript
JS实现的适合做faq或menu滑动效果示例
2016/11/17 Javascript
canvas学习之API整理笔记(一)
2016/12/29 Javascript
详解Vue 实例中的生命周期钩子
2017/03/21 Javascript
微信小程序显示下拉列表功能【附源码下载】
2017/12/12 Javascript
AngularJS使用ui-route实现多层嵌套路由的示例
2018/01/10 Javascript
js中getBoundingClientRect的作用及兼容方案详解
2018/02/01 Javascript
在vue项目中使用element-ui的Upload上传组件的示例
2018/02/08 Javascript
浅析Vue实例以及生命周期
2018/08/14 Javascript
微信小程序授权登录解决方案的代码实例(含未通过授权解决方案)
2019/05/10 Javascript
Layui给switch添加响应事件的例子
2019/09/03 Javascript
vue中echarts图表大小适应窗口大小且不需要刷新案例
2020/07/19 Javascript
Python socket.error: [Errno 98] Address already in use的原因和解决方法
2014/08/25 Python
Python3使用SMTP发送带附件邮件
2020/06/16 Python
Python 按字典dict的键排序,并取出相应的键值放于list中的实例
2019/02/12 Python
Python实现将HTML转成PDF的方法分析
2019/05/04 Python
马德里著名的运动鞋商店:NOIRFONCE
2019/04/12 全球购物
经典c++面试题二
2015/08/14 面试题
C#怎么让一个窗口居中显示?
2015/10/20 面试题
党员学习十八大感想
2014/01/17 职场文书
人事部专员岗位职责
2014/03/04 职场文书
少先队学雷锋活动月总结
2014/03/09 职场文书
小学红领巾广播稿(3篇)
2014/09/13 职场文书
2014机关干部学习“焦裕禄精神”思想汇报
2014/09/19 职场文书
2015年度党风廉政建设工作情况汇报
2015/01/02 职场文书
关于成立领导小组的通知
2015/04/23 职场文书
pytorch实现线性回归以及多元回归
2021/04/11 Python
Java Spring Boot 正确读取配置文件中的属性的值
2022/04/20 Java/Android