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实现可拖动的魔方3d效果
May 07 HTML / CSS
详解CSS3中常用的样式【基本文本和字体样式】
Oct 20 HTML / CSS
html5应用缓存_动力节点Java学院整理
Jul 13 HTML / CSS
使用HTML5的链接预取功能(link prefetching)给网站提速
Dec 13 HTML / CSS
几个解决兼容IE6\7\8不支持html5标签的几个方法
Jan 07 HTML / CSS
IE10 Error.stack 让脚本调试更加方便快捷
Apr 22 HTML / CSS
HTML5 LocalStorage 本地存储刷新值还在
Mar 10 HTML / CSS
canvas之自定义头像功能实现代码示例
Sep 29 HTML / CSS
3种方式实现瀑布流布局小结
Sep 05 HTML / CSS
CSS3实现的水平标题菜单
Apr 14 HTML / CSS
关于HTML编码导致的乱码问题
Sep 04 HTML / CSS
CSS控制继承中的height能变为可继承吗
Jun 10 HTML / CSS
使用canvas仿Echarts实现金字塔图的实例代码
CSS中妙用 drop-shadow 实现线条光影效果
仅仅使用 HTML/CSS 实现各类进度条的方式汇总
纯 CSS 自定义多行省略的问题(从原理到实现)
CSS作用域(样式分割)的使用汇总
使用CSS实现小三角边框原理解析
CSS实现切角+边框+投影+内容背景色渐变效果
You might like
PHP实现AES256加密算法实例
2014/09/22 PHP
php随机抽奖实例分析
2015/03/04 PHP
详谈PHP中的密码安全性Password Hashing
2017/02/04 PHP
php分页查询的简单实现代码
2017/03/14 PHP
PHP长网址与短网址的实现方法
2017/10/13 PHP
php中加密解密DES类的简单使用方法示例
2020/03/26 PHP
自动刷新网页,自动刷新当前页面,JS调用
2013/06/24 Javascript
javascript自然分类法算法实现代码
2013/10/11 Javascript
构造函数+原型模式构造js自定义对象(最通用)
2014/05/12 Javascript
jQuery实现的原图对比窗帘效果
2014/06/15 Javascript
jquery实现的下拉和收缩效果示例
2014/08/21 Javascript
js实现鼠标划过给div加透明度的方法
2015/05/25 Javascript
jQuery div拖拽用法实例
2016/01/14 Javascript
gulp-uglify 与gulp.watch()配合使用时报错(重复压缩问题)
2016/08/24 Javascript
Bootstrap媒体对象学习使用
2017/03/07 Javascript
详解vue 配合vue-resource调用接口获取数据
2017/06/22 Javascript
Node.js笔记之process模块解读
2018/05/31 Javascript
Vue作用域插槽slot-scope实例代码
2018/09/05 Javascript
JavaScript使用小插件实现倒计时的方法讲解
2019/03/11 Javascript
详解用Webpack与Babel配置ES6开发环境
2019/03/12 Javascript
vue2配置scss的方法步骤
2019/06/06 Javascript
微信小程序实现张图片合成为一张并下载
2019/07/16 Javascript
python绘图库Matplotlib的安装
2014/07/03 Python
详解Python发送邮件实例
2016/01/10 Python
Python机器学习算法之k均值聚类(k-means)
2018/02/23 Python
Python向Excel中插入图片的简单实现方法
2018/04/24 Python
python使用selenium登录QQ邮箱(附带滑动解锁)
2019/01/23 Python
Pytorch 使用不同版本的cuda的方法步骤
2020/04/02 Python
13个Pandas实用技巧,助你提高开发效率
2020/08/19 Python
英超联赛的首选足球:Mitre足球
2019/05/06 全球购物
澳大利亚一站式数码相机商店:CameraPro
2020/03/09 全球购物
这76道Java面试题及答案,祝你能成功通过面试
2016/04/16 面试题
演讲稿开场白
2014/01/13 职场文书
2015年酒店工作总结范文
2015/04/07 职场文书
读《教育心理学》心得体会
2016/01/22 职场文书
Python实现为PDF去除水印的示例代码
2022/04/03 Python