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混合模式mix-blend-mode/background-blend-mode简介
Mar 15 HTML / CSS
通过css3动画和opacity透明度实现呼吸灯效果
Aug 09 HTML / CSS
CSS中垂直居中的简单实现方法
Jul 06 HTML / CSS
基于CSS3制作立体效果导航菜单
Jan 12 HTML / CSS
利用CSS3 动画 绘画 圆形动态时钟
Mar 20 HTML / CSS
你可能不熟练的十个前端HTML5经典面试题
Jul 03 HTML / CSS
HTML5 创建canvas元素示例代码
Jun 04 HTML / CSS
HTML5新增的表单元素和属性实例解析
Jul 07 HTML / CSS
HTML5所有标签汇总及标签意义解释
Mar 12 HTML / CSS
详解HTML5中rel属性的prefetch预加载功能使用
May 06 HTML / CSS
phonegap常用事件总结(必看篇)
Mar 31 HTML / CSS
amazeui页面分析之登录页面的示例代码
Aug 25 HTML / CSS
使用canvas仿Echarts实现金字塔图的实例代码
CSS中妙用 drop-shadow 实现线条光影效果
仅仅使用 HTML/CSS 实现各类进度条的方式汇总
纯 CSS 自定义多行省略的问题(从原理到实现)
CSS作用域(样式分割)的使用汇总
使用CSS实现小三角边框原理解析
CSS实现切角+边框+投影+内容背景色渐变效果
You might like
繁体中文转换为简体中文的PHP函数
2006/10/09 PHP
PHP加密扩展库Mcrypt安装和实例
2013/11/10 PHP
php截取中文字符串函数实例
2015/02/23 PHP
浅谈PHP检查数组中是否存在某个值 in_array 函数
2016/06/13 PHP
javascript:void(0)的真正含义实例分析
2008/08/20 Javascript
JavaScript闭包 懂不懂由你反正我是懂了
2011/10/21 Javascript
文本框回车提交与禁止提交示例
2013/09/27 Javascript
js中判断用户输入的值是否为空的简单实例
2013/12/23 Javascript
node.js中格式化数字增加千位符的几种方法
2015/07/03 Javascript
JS模拟按钮点击功能的方法
2015/12/22 Javascript
nodejs async异步常用函数总结(推荐)
2017/11/17 NodeJs
jQuery实现页码跳转式动态数据分页
2017/12/31 jQuery
Angular实现下拉框模糊查询功能示例
2018/01/03 Javascript
jquery实现点击弹出对话框
2020/02/08 jQuery
vue中解决拖拽改变存在iframe的div大小时卡顿问题
2020/07/22 Javascript
python使用smtplib模块通过gmail实现邮件发送的方法
2015/05/08 Python
Python文件操作基本流程代码实例
2017/12/11 Python
基于Python实现的微信好友数据分析
2018/02/26 Python
Python爬虫抓取技术的一些经验
2019/07/12 Python
pytorch实现特殊的Module--Sqeuential三种写法
2020/01/15 Python
使用python实现多维数据降维操作
2020/02/24 Python
matplotlib之pyplot模块之标题(title()和suptitle())
2021/02/22 Python
基于html和CSS3制作酷炫的导航栏
2015/09/23 HTML / CSS
深入研究HTML5实现图片压缩上传功能
2016/03/25 HTML / CSS
Opodo意大利:欧洲市场上领先的在线旅行社
2019/10/24 全球购物
什么是网络协议
2016/04/07 面试题
青年文明号复核材料
2014/02/11 职场文书
贷款担保书范文
2014/05/13 职场文书
个人汇报材料范文
2014/12/30 职场文书
出生证明范本
2015/06/15 职场文书
组织委员竞选稿
2015/11/21 职场文书
毕业生求职自荐信(2016最新版)
2016/01/28 职场文书
《游戏公平》教学反思
2016/02/20 职场文书
SONY AN-LP1 短波有源天线放大器
2021/04/22 无线电
Python之基础函数案例详解
2021/08/30 Python
分享MySQL常用 内核 Debug 几种常见方法
2022/03/17 MySQL