经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » HTML5 » 查看文章
Html5同时支持多端sdk的小技巧_html5
来源:jb51  时间:2021/11/15 20:03:13  对本文有异议

需求

在实际项目中,我们通常会需要做一些跨多平台的页面。比如说一个活动页面,需要在微信小程序里展示,也需要在自家公司的app里面展示,还需要在支付宝等平台里面展示。这时候一个h5就是很符合你的需要了。如果这个时候需求再复杂一些,比如说在这个活动页面需要调些扫码功能,或者需要调起支付功能,等原生方法调用的需求,那么这个时候你需要一个中间件,来处理不同端的原生方法。

中间件实现原理

原理很简单,我们在抽象出来一个类,在这类里面,我们将需要用到原生的方法进行实现,其他终端对这个类进行继承并重写所有的方法。

偷懒的话,可以不要pc调试类,直接在父类实现pc调试类里的所有方法。
实现完了,接下来就是调用了,如果在每个页面都判断终端是哪端就太麻烦了,并且也没有必要把每端的中间件代码都加载进来(可以使用require进行异步加载)。在页面加载的过程中,根据判断创建对应终端的中间件对象addon,并将这个中间件对象挂载到window上面,在使用时候就可以直接使用window.addon.scan()

注意点

微信、支付宝都有其对应的判断方法,但自家app的判断, 需要原生开发在userAgent里面添加标识(这个不复杂,原生都知道怎么加,不知道的请问度娘)
另外ios webview不再支持同步方法,建议所有的方法采用异步调用方式, 参考示例。

上代码

下面上一段我的判断各端的代码

  1. class Addon {
  2. constructor () {
  3. let ua = window.navigator.userAgent.toLowerCase()
  4. if (/MPBank/.test(window.navigator.userAgent)) {
  5. // 招商行小程序
  6. } else if (ua.match(/MicroMessenger/i) == 'micromessenger') {
  7. // 大部分手机可采用此判断,是否是小程序,但有小部分华为等手机因为加载慢,这里会出现误判
  8. if (window.__wxjs_environment === 'miniprogram' || ua.match(/miniprogram/i) == 'miniprogram') {
  9. } else {
  10. }
  11. } else if (/AlipayClient/.test(window.navigator.userAgent)) {
  12. // 此处用ua和miniprogram判断,先查看兼容性,使用my.getEnv为异步,不适合此处
  13. if (ua.match(/miniprogram/i) == 'miniprogram' || ua.match(/webview/i) == 'webview') {
  14. // 支付宝小程序
  15. } else {
  16. // 支付宝
  17. }
  18. } else if (/xxxx-app/.test(window.navigator.userAgent)) {
  19. // app
  20. } else {
  21. // 其他处理(web和第三方渠道进入) 兜底
  22. }
  23. }
  24.  
  25. export let addon = new Addon()

下面是一个简单的方法示例
ParentAddon.js

  1. export default class ParentAddon {
  2. scan (data) {
  3. data.success('xxx')
  4. }
  5. }

IosAppAddon.js

  1. export default class IosAppAddon extends ParentAddon {
  2. scan (data) {
  3. window.scanCallback = data.success
  4. window.webkit.messageHandlers.scan.postMessage({
  5. callBack: 'scanCallback'
  6. })
  7. }
  8. }

到此这篇关于Html5同时支持多端sdk的小技巧的文章就介绍到这了,更多相关Html5多端sdk内容请搜索w3xue以前的文章或继续浏览下面的相关文章,希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号