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实现的文字亮光特效的代码演示
Nov 27 HTML / CSS
纯HTML5+CSS3制作图片旋转
Jan 12 HTML / CSS
css3实现冲击波效果的示例代码
Jan 11 HTML / CSS
HTML5 canvas基本绘图之绘制阴影效果
Jun 27 HTML / CSS
HTML5 本地存储实现购物车功能
Sep 07 HTML / CSS
html5实现的便签特效(实战分享)
Nov 29 HTML / CSS
html5本地存储之localstorage 、本地数据库、sessionStorage简单使用示例
May 08 HTML / CSS
HTML5进度条特效
Dec 18 HTML / CSS
微信浏览器取消缓存的方法
Mar 28 HTML / CSS
HTML5 Canvas 实现K线图的示例代码
Dec 23 HTML / CSS
记一次高分屏下canvas模糊问题
Feb 17 HTML / CSS
html5拖拽应用记录及注意点
May 27 HTML / CSS
使用canvas仿Echarts实现金字塔图的实例代码
CSS中妙用 drop-shadow 实现线条光影效果
仅仅使用 HTML/CSS 实现各类进度条的方式汇总
纯 CSS 自定义多行省略的问题(从原理到实现)
CSS作用域(样式分割)的使用汇总
使用CSS实现小三角边框原理解析
CSS实现切角+边框+投影+内容背景色渐变效果
You might like
php抓取https的内容的代码
2010/04/06 PHP
php 的多进程操作实践案例分析
2020/02/28 PHP
使用jQuery实现dropdownlist的联动效果(sharepoint 2007)
2011/03/30 Javascript
jQuery EasyUI API 中文文档 - Panel面板
2011/09/30 Javascript
IE和Firefox的Javascript兼容性总结[推荐收藏]
2011/10/19 Javascript
别了 JavaScript中的isXX系列
2012/08/01 Javascript
jQuery toggleClass应用实例(附效果图)
2014/04/06 Javascript
JavaScript实现数字数组正序排列的方法
2015/04/06 Javascript
在JavaScript中处理时间之setMinutes()方法的使用
2015/06/11 Javascript
轻量级javascript 框架Backbone使用指南
2015/07/24 Javascript
jQuery 1.9.1源码分析系列(十)事件系统之绑定事件
2015/11/19 Javascript
JavaScript表单验证完美代码
2017/03/02 Javascript
nodejs微信扫码支付功能实现
2018/02/17 NodeJs
vue项目中使用ueditor的实例讲解
2018/03/05 Javascript
vue列表单项展开收缩功能之this.$refs的详解
2019/05/05 Javascript
ES10的13个新特性示例(小结)
2019/09/23 Javascript
JQuery实现折叠式菜单的详细代码
2020/06/03 jQuery
JavaScript实现世界各地时间显示
2020/09/07 Javascript
[58:29]DOTA2-DPC中国联赛 正赛 Phoenix vs XG BO3 第一场 1月31日
2021/03/11 DOTA
python文件特定行插入和替换实例详解
2017/07/12 Python
Python实现识别手写数字大纲
2018/01/29 Python
Python实现字典排序、按照list中字典的某个key排序的方法示例
2018/12/18 Python
在django模板中实现超链接配置
2019/08/21 Python
python GUI库图形界面开发之PyQt5图片显示控件QPixmap详细使用方法与实例
2020/02/27 Python
Python selenium抓取虎牙短视频代码实例
2020/03/02 Python
python中wheel的用法整理
2020/06/15 Python
CSS3实现各种图形的示例代码
2016/10/19 HTML / CSS
纪伊国屋泰国网上书店:Kinokuniya泰国
2017/12/24 全球购物
触发器(trigger)的功能都有哪些?写出一个触发器的例子
2012/09/17 面试题
酒店前台接待岗位职责
2013/12/03 职场文书
大学生找工作求职信
2014/07/09 职场文书
教师见习报告范文
2014/11/03 职场文书
普通党员群众路线教育实践活动心得体会
2014/11/04 职场文书
请病假条范文
2015/08/17 职场文书
Django集成富文本编辑器summernote的实现步骤
2021/05/31 Python
PostgreSQL数据库去除重复数据和运算符的基本查询操作
2022/04/12 PostgreSQL