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 相关文章推荐
CSS心形加载的动画源码的实现
Mar 09 HTML / CSS
CSS3教程(10):CSS3 HSL声明设置颜色
Apr 02 HTML / CSS
css3+伪元素实现鼠标移入时下划线向两边展开的效果
Apr 25 HTML / CSS
HTML5中FileReader接口使用方法实例详解
Aug 26 HTML / CSS
HTML5的结构和语义(2):结构
Oct 17 HTML / CSS
HTML5 Web存储方式的localStorage和sessionStorage进行数据本地存储案例应用
Dec 09 HTML / CSS
HTML5中判断用户是否正在浏览页面的方法
May 03 HTML / CSS
关于HTML5语义标签的实践(blog页面)
Jul 12 HTML / CSS
使用Html5多媒体实现微信语音功能
Jul 26 HTML / CSS
Html5移动端网页端适配(js+rem)
Feb 03 HTML / CSS
css3实现的加载动画效果
Apr 07 HTML / CSS
DIV CSS实现网页背景半透明效果
Dec 06 HTML / CSS
使用canvas仿Echarts实现金字塔图的实例代码
CSS中妙用 drop-shadow 实现线条光影效果
仅仅使用 HTML/CSS 实现各类进度条的方式汇总
纯 CSS 自定义多行省略的问题(从原理到实现)
CSS作用域(样式分割)的使用汇总
使用CSS实现小三角边框原理解析
CSS实现切角+边框+投影+内容背景色渐变效果
You might like
PHP定时自动生成静态HTML的实现代码
2010/06/20 PHP
php array_filter除去数组中的空字符元素
2020/06/21 PHP
php操作xml并将其插入数据库的实现方法
2016/09/08 PHP
js实现的网站首页随机公告随机公告
2007/03/14 Javascript
javascript生成/解析dom的CDATA类型的字段的代码
2007/04/22 Javascript
Javascript创建自定义对象 创建Object实例添加属性和方法
2012/06/04 Javascript
Javascript实现简单的富文本编辑器附演示
2014/06/16 Javascript
前端轻量级MVC框架CanJS详解
2014/09/26 Javascript
推荐8款jQuery轻量级树形Tree插件
2014/11/12 Javascript
javascript获取当前的时间戳的方法汇总
2015/07/26 Javascript
onclick和onblur冲突问题的快速解决方法
2016/04/28 Javascript
JavaScript基本类型值-Number类型
2017/02/24 Javascript
详解如何在 vue 项目里正确地引用 jquery 和 jquery-ui的插件
2017/06/01 jQuery
vue.js学习之vue-cli定制脚手架详解
2017/07/02 Javascript
解决layui前端框架 form表单,table表等内置控件不显示的问题
2018/08/19 Javascript
jquery判断滚动条距离顶部的距离方法
2018/09/05 jQuery
微信接入之获取用户头像的方法步骤
2019/09/23 Javascript
python处理文本文件并生成指定格式的文件
2014/07/31 Python
在Docker上开始部署Python应用的教程
2015/04/17 Python
Centos Python2 升级到Python3的简单实现
2016/06/21 Python
R vs. Python 数据分析中谁与争锋?
2017/10/18 Python
uwsgi+nginx部署Django项目操作示例
2018/12/04 Python
python中的itertools的使用详解
2020/01/13 Python
谈一谈数组拼接tf.concat()和np.concatenate()的区别
2020/02/07 Python
python3 字符串知识点学习笔记
2020/02/08 Python
在pycharm中实现删除bookmark
2020/02/14 Python
通过Django Admin+HttpRunner1.5.6实现简易接口测试平台
2020/11/11 Python
python实现跨年表白神器--你值得拥有
2021/01/04 Python
详解HTML5常用的语义化标签
2019/09/27 HTML / CSS
英国在线房屋中介网站:Yopa
2018/01/09 全球购物
生产经理的自我评价分享
2013/11/07 职场文书
机电一体化专业推荐信
2013/12/03 职场文书
门诊手术室工作制度
2014/01/30 职场文书
党的群众路线剖析材料
2014/10/09 职场文书
详解Js模块化的作用原理和方案
2021/04/29 Javascript
如何用H5实现好玩的2048小游戏
2022/07/23 HTML / CSS