写一个易于维护使用方便性能可靠的Hybrid框架(一)

栏目: IOS · Android · 发布时间: 6年前

内容简介:本来上一篇博文写完,我就告诉自己,这是最后一篇,之后不再总结和Cordova相关和web容器相关的内容,但是,很不巧,我昨天总结完不扯那么多了,还是基于这个想法,我决定给自己总结一个自己的Hybird框架,一方面属于知识的总结,年纪大了不总结就忘是真的,另一方面算是对自己知识的扩展延伸,希望多像大神学习...另外,味精大佬的思想是框架内并不自己构建webView,而是开发人员完全使用自己的webView即可,那么我也在纠结,到底要不要开发者自己控制webView还是说框架内控制?那么我先在大佬的基础上做下

本来上一篇博文写完,我就告诉自己,这是最后一篇,之后不再总结和Cordova相关和web容器相关的内容,但是,很不巧,我昨天总结完 关于Cordova框架对URL拦截导致通信丢失问题的处理 之后,又看了味精大佬的 从零收拾一个hybrid框架(二)-- WebView容器基础功能设计思路 (别问我3月份的文章为何才看到,因为我才路转的掘金)之后,我又按耐不住自己了(PS:我本来是没想研究这么深的,但是,停不下来了),那我就问自己,如果是我呢,因为我一直在总结Cordova的思想,那么如果是我设计一个Hybrid框架,我要怎么做?于是我又陷入了沉思...因为我本来是想在后续着重研究weex,RN等动态UI方面的实现的,讲真的通过味精大佬的分析,我现在也不确定到底是我们的web容器更好还是基于weex等的动态UI更好,于是我又陷入了沉思...经过深思之后,我决定还是继续研究后者,个人觉得这是大前端的趋势,什么是大前端,就是各种的各种前端客户端糅合在了一起,四处交叉延伸,不分你我。

不扯那么多了,还是基于这个想法,我决定给自己总结一个自己的Hybird框架,一方面属于知识的总结,年纪大了不总结就忘是真的,另一方面算是对自己知识的扩展延伸,希望多像大神学习...另外,味精大佬的思想是框架内并不自己构建webView,而是开发人员完全使用自己的webView即可,那么我也在纠结,到底要不要开发者自己控制webView还是说框架内控制?那么我先在大佬的基础上做下延伸扩展,决定框架内不提供webView,webView的创建由开发者自己控制。

那么现在就有了两个前提:一是webView使用WKWebView,二是框架内不提供webView,webView需要开发者自己创建。下面进入正题:

一个好的Hybrid框架应该具有哪有特点:

1.插件化,这个是必须的,解耦没毛病,什么叫插件化,就是可插拔,用的时候拽进来,不用的时候拖出去,其余什么都不用干。说实话这很符合Cordova(优点太多离不开了),插件化又可以细分:

  • 1.webView的代理方法具体实现插件化,这样不管哪个webView的代理方法都可以随意设置而不会影响业务。
  • 2.js与native交互插件化,就是我们所谓的js插件,native插件,它们统一叫插件(比如fetch,io等),配对插配对拔,具体看业务需求。

2.可配置性,就是说一切皆可配置,所有的插件,都是被一个配置文件搞定的,也就是说一个配置文件即可搞定上面提到的一切插件。配置又可以细分:

  • 1.插件可配置,插件的可配置又细分为native端的插件可配置和js端的插件可配置。
  • 2.插件是否在加载webView时就加载到缓存里面还是说在调用的时候在加载,这个要看具体业务,个人觉得常用的插件,例如fetch插件,js的网络请求都使用native来做,这种插件是完全有必要提前加载的,像地图这类插件,可能偶尔会用一次或者用户一时半会用不到,这类插件就完全可以在调用的时候再实例化放入缓存。

3.对于前端开发者来说接口统一,并且框架内怎么变也不需要js做改动,对于前端来说,始终是一套接口,他不需要关心webView具体是啥。

  • 需要提供出一套前端接口给前端开发者。

4.通信上必须用WKWebView,因为它对性能的提升是显而易见的,而且不得不用,webView这一块打算参考味精大佬所选择的通信方式。具体可以参考

5.js与native插件交互的性能优化。这一块又可以细分三部分:

  • 1.js调用native是否需要搞个队列,像我上一篇所提到的,是不是不需要每次调用都要经过webView?那么同样native端是否一样也需要搞个队列出来(Cordova思想,别问我为什么,我也不知道)。
  • 2.插件回调一旦耗时,是否需要将其放入后台线程执行?
  • 3.我在浅析iOS-Cordova里面提到过一点,如果插件执行时间过长造成卡顿,向runloop中添加了一个timer来唤醒runloop继续干活,防止休眠,那么我们是不是也可以将它带过来。

我就想到了上面的五点,不过感觉有这五点也差不多了,就这些吧,那接下来要做的事情就是,一步一步的解决上面的五个问题,主题思想还是抽离前两篇文章外加Cordova框架思想,毕竟Cordova有点重量级有些是我们平时开发用不到的,而且集成起来也比较麻烦,基于此,打算造一个性能可靠,使用方便,易于维护且轻量级的Hybrid框架出来。目前构建了思路,具体实现准备放在下一篇(PS:因为我现在也没想好,太晚了,就到这吧)来写。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Python机器学习基础教程

Python机器学习基础教程

[德]安德里亚斯·穆勒、[美]莎拉·吉多 / 张亮 / 人民邮电出版社 / 2018-1 / 79.00元

本书是机器学习入门书,以Python语言介绍。主要内容包括:机器学习的基本概念及其应用;实践中最常用的机器学习算法以及这些算法的优缺点;在机器学习中待处理数据的呈现方式的重要性,以及应重点关注数据的哪些方面;模型评估和调参的高级方法,重点讲解交叉验证和网格搜索;管道的概念;如何将前面各章的方法应用到文本数据上,还介绍了一些文本特有的处理方法。一起来看看 《Python机器学习基础教程》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试