DreamBox统一视图开发框架

联合创作 · 2023-09-24 21:02

DreamBox 是一个为客户端打造的、具有动态化功能、性能优秀的统一视图开发框架。

DreamBox 本身是一个视图容器,容器内部的内容可以通过线上下发的方式任意动态化更新。而且并不集成运行时虚拟机,最大程度贴近原生开发,没有中间商吃内存、耗性能。

目标

DreamBox立志于能在双端的原生视图框架和运行时之上搭建一个统一的、具备动态化能力、可以灵活扩展的视图开发框架,同时保持优秀的运行时性能,并不断建设组件和落地生态,降低50%的客户端视图开发工作量,让开发人员腾出双手做更多更有意义的事情。

基本原理

DreamBox选择了:

  1. 仿照Android约束布局进行DSL的初版定义,后期结合实际情况分支发展。这样一来,大大降低Android开发者的学习门槛。另外,有限的DSL规则和属性远比学习一门真正的语言来的更快,iOS开发同学的掌握速度也较快
  2. 不集成语言运行时,进行静态解析。通过这种方式,让DB的运行时生命周期足够短暂,避免依附View存活而带来的持续的内存消耗问题。另一方面,因为没有语言运行时,动态解析的性能损耗大大降低

粗粒度上,DreamBox通过以下几个步骤完成了整体功能:

  1. 开发者编写DSL
  2. 编译器编译DSL为DB Runtime可以接受的数据格式
  3. DB Runtime解析数据并映射为原生数据、绑定交互事件
  4. 原生运行时进行渲染并传递交互事件
  5. DB Runtime响应交互事件做动作

简而言之,DreamBox定义了一套统一的DSL,在Android和iOS的原生视图框架和运行时的基础上,搭建了另一个运行时。这个运行时生命周期短、内存损耗小,将这一套DSL分别映射成两个系统能够接受的数据,完成了展现一致、体验一致的视图页面。

功能特性

先通过一个Gif简单认识下

DreamBox将一个视图中的各种元素分为三类:

  1. 视图元素,这类元素就是直接展示在用户眼前的View。这类元素可以动态化改变其内部属性和外部布局
  2. 交互、回调元素,视图的点击、长按等交互事件或动作发生后的回调统称为这类元素。它们是视图背后交互逻辑的触发点
  3. 动作元素,如网络请求、日志、弹窗、打电话等等这些隐藏在视觉背后的、由交互、回调元素触发的归为此类

比如:一个卡片的组成是图片+按钮,当按钮点击时,跳转另一个页面。这句话中,图片、按钮以及他们的布局关系就是视觉元素,按钮的点击就是交互、回调元素,最后的跳转就是动作元素

DreamBox所支持的功能特性有:

  1. 支持视图元素的复杂约束关系布局,每一个元素可以在横纵坐标轴上相对于其他元素进行标记定位,相比flex这能支持一些更复杂的场景需求
  2. 不仅仅是视图元素,支持对以上三个元素都进行动态修改
  3. 支持三方进行DSL扩展,以适应更加复杂、更加具体的需求场景
  4. 支持通过Event API与原生运行时进行双工通信,满足一些DB框架无法满足的功能需求
  5. 支持通过Playgrounddebug-tool的集成达成实时调试预览的效果
  6. 支持单个App中多个引擎实例集成,互不干扰
  7. 支持复杂的数据使用场景,包含内置固定、二次请求以及原生透传
  8. 内置10余个视图组件,包含列表和流式布局
  9. 内置10余个动作功能,部分基础功能接入方可以自行接管具体实现
  10. 细粒度低至View,可在页面中自由嵌入使用

详细功能请参见开发手册

 

浏览 8
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报