Html5同时支持多端sdk的小技巧
2021-11-23 04:07
1111 查看
需求
在实际项目中,我们通常会需要做一些跨多平台的页面。比如说一个活动页面,需要在微信小程序里展示,也需要在自家公司的app里面展示,还需要在支付宝等平台里面展示。这时候一个h5就是很符合你的需要了。如果这个时候需求再复杂一些,比如说在这个活动页面需要调些扫码功能,或者需要调起支付功能,等原生方法调用的需求,那么这个时候你需要一个中间件,来处理不同端的原生方法。
中间件实现原理
原理很简单,我们在抽象出来一个类,在这类里面,我们将需要用到原生的方法进行实现,其他终端对这个类进行继承并重写所有的方法。
偷懒的话,可以不要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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!
相关文章推荐
- iOS SDK同时支持模拟器和真机的静态包编译脚本
- 使Android 自带SDK 完美支持HTML5 之 html5webview
- 使Android 自带SDK 完美支持HTML5 之 html5webview
- 使Android 自带SDK 完美支持HTML5 之 html5webview
- Html5下拉控件同时支持文本输入和下拉代码
- AdMob SDK更新, 支持Windows Phone 7及HTML5
- 模仿微信朋友圈 仿微信js-sdk wx.previewImage javascript实现,支持图片预览,滑动切换,双指缩放,图片缓存 h5 html5 js
- 解决内外网无法同时访问的小技巧
- 【已过时,新的sdk和框架默认支持】AFNetworking 支持cookies的解决方案
- Notepad++支持jQuery、html5、css3
- 最近成果-透明加密文件系统SDK-支持透明加密解密-手动加密解密-目录加密解密-指定进程加密-指定后缀加密-指定非法进程-锁定驱动器-支持Office文件加密解密-打开文件时加密等
- ASP.NET DEMO 15: 同时支持行单击和双击事件的 GridView/DataGrid
- Android7.0 JACK编译器不支持多用户同时编译的问题的解决
- HTML5之浏览器支持、新元素
- HTML5-WebSocket实现多文件同时上传
- 使 egg-multipart 同时支持 stream 和 file
- 让IE浏览器支持HTML5标准的方法
- 支持移动平台的Html5播放器
- GridView同时支持行单击和双击事件的
- (0009) iOS 开发之友盟统计分析SDK已全面支持HTTPS的更新