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实现的阴影效果
Dec 24 HTML / CSS
使用CSS3实现SVG路径描边动画效果入门教程
Oct 21 HTML / CSS
详解CSS3媒体查询响应式布局bootstrap 框架原理实战(推荐)
Nov 16 HTML / CSS
CSS3 filter(滤镜)实现网页灰色或者黑色模式的示例代码
Feb 24 HTML / CSS
HTML5 File接口在web页面上使用文件下载
Feb 27 HTML / CSS
基于HTML5超酷摄像头(HTML5 webcam)拍照功能实现代码
Dec 13 HTML / CSS
用html5绘制折线图的实例代码
Mar 25 HTML / CSS
HTML5 虚拟键盘出现挡住输入框的解决办法
Feb 14 HTML / CSS
HTML5 LocalStorage 本地存储刷新值还在
Mar 10 HTML / CSS
Canvas绘制浮动球效果的示例
Dec 29 HTML / CSS
HTML5中form如何关闭自动完成功能的方法
Jul 02 HTML / CSS
老生常谈 使用 CSS 实现三角形的技巧(多种方法)
Apr 13 HTML / CSS
使用canvas仿Echarts实现金字塔图的实例代码
CSS中妙用 drop-shadow 实现线条光影效果
仅仅使用 HTML/CSS 实现各类进度条的方式汇总
纯 CSS 自定义多行省略的问题(从原理到实现)
CSS作用域(样式分割)的使用汇总
使用CSS实现小三角边框原理解析
CSS实现切角+边框+投影+内容背景色渐变效果
You might like
php&java(一)
2006/10/09 PHP
php+mysqli批量查询多张表数据的方法
2015/01/29 PHP
基于PHP生成简单的验证码
2016/06/01 PHP
js DOM模型操作
2009/12/28 Javascript
基于jquery实现控制经纬度显示地图与卫星
2013/05/20 Javascript
jquery mobile动态添加元素之后不能正确渲染解决方法说明
2014/03/05 Javascript
javascript计时器详解
2015/02/28 Javascript
基于nodejs+express(4.x+)实现文件上传功能
2015/11/23 NodeJs
jQuery ajax提交Form表单实例(附demo源码)
2016/04/06 Javascript
jquery插件锦集【推荐】
2016/12/16 Javascript
Vue分页组件实例代码
2017/04/17 Javascript
通过实践编写优雅的JavaScript代码
2019/05/30 Javascript
记录vue做微信自定义分享的一些问题
2019/09/12 Javascript
React 实现车牌键盘的示例代码
2019/12/20 Javascript
javascript设计模式 ? 职责链模式原理与用法实例分析
2020/04/16 Javascript
[05:31]干嘛呢兄弟!DOTA2 TI9语音轮盘部分出处
2019/05/14 DOTA
详解在Python程序中使用Cookie的教程
2015/04/30 Python
使用Python+Splinter自动刷新抢12306火车票
2018/01/03 Python
Python实现合并同一个文件夹下所有PDF文件的方法示例
2018/04/28 Python
详解Python if-elif-else知识点
2018/06/11 Python
python石头剪刀布小游戏(三局两胜制)
2021/01/20 Python
Python re 模块findall() 函数返回值展现方式解析
2019/08/09 Python
python 计算方位角实例(根据两点的坐标计算)
2020/01/17 Python
Python PIL库图片灰化处理
2020/04/07 Python
Python基于httpx模块实现发送请求
2020/07/07 Python
英国著名的小众美容品牌网站:Alyaka
2017/08/08 全球购物
WiFi云数码相框:Nixplay
2018/07/05 全球购物
Sport-Thieme荷兰:购买体育用品
2019/08/25 全球购物
C#如何进行LDAP用户校验
2012/11/21 面试题
办公室主任职责范文
2013/11/08 职场文书
大学在校生求职信范文
2013/11/21 职场文书
工作表现自我评价
2014/02/08 职场文书
公司寄语大全
2014/04/10 职场文书
副护士长竞聘演讲稿
2014/04/30 职场文书
五星红旗迎风飘扬观后感
2015/06/17 职场文书
消费者投诉书范文
2015/07/02 职场文书