• Stars
    star
    166
  • Rank 227,748 (Top 5 %)
  • Language
    Java
  • License
    Apache License 2.0
  • Created about 4 years ago
  • Updated over 3 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

DreamBox是一个为客户端开发者打造的统一视图开发框架,具有性能好、可动态更新的特点

License

简介


这是一个为客户端打造的、具有动态化功能、性能优秀的统一视图开发框架——`One DSL, Both run`

产生背景

身为客户端开发同学的你,是否遇到过以下问题:

  1. 要开发一个运营位,按钮一会想在上边,一会想在下边,预埋?可以cover住所有情况吗?
  2. 已有的一些信息卡片,内容中的标签想挪到上边去,开发量不大,10分钟就调完的东西却不得不通过发版解决
  3. 紧急的需求来了,要在首页上展示一个新型样式的运营活动,除了借用Webview有更好的办法吗?千万量级用户的背景下,真的所有人的内存都撑得住吗?

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

目标

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

基本原理

DreamBox的发起和发展都离不开“前辈”们的点醒。我们深入调研了像RN、Weex、Flutter、Tangram等优秀框架,结合所处的业务环境特点和自身的核心诉求,选择了广泛吸取前辈经验和优点,自立门户。
“前辈”们基本上都是能独当一面的全能型选手,甚至具有独立开发整个App的能力。当然,这受益于Javascript、Dart及其运行时。实际开发中,这带来了两个问题:

  1. 是否大家都能够良好掌握JS或Dart语言
  2. 针对一些简单的卡片乃至页面,这些大型框架显然可以应对,但随之而来的内存和性能损耗,有杀鸡用牛刀的架势

当然,这里再额外提一句,Flutter官方并未提供动态更新功能。

基于以上,我们认为:复杂的场景上我们可以充分利用已有框架的能力,支持复杂场景、复杂交互,随之而来的开发成本和内存等消耗是值得的。但在简单场景中,比如一些没有复杂交互需求,只是进行信息展示的需求,能以更快速、更轻便的方案进行支撑。
我们希望:一方面能不能通过简单的语言学习甚至于基于已有的就可以进行双端开发;另一方面,内存和性能的额外消耗是否可以压至最低,无限接近原生。所以,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简单认识下

demo 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,可在页面中自由嵌入使用

详细功能请参见开发手册

在路上

  1. 扩展框架优化,方便开发者在两个平台上能更加快速的扩展新View以及Action
  2. 类链式布局支持,实际开发场景中迫切需要此类功能以达到整体居中等诉求
  3. 扩展更多内置组件,以及对一些内置组件支持更多的功能、属性
  4. 在数据属性中支持简单的语义解析
  5. 支持原生Runtime从DB Runtime中获取已经渲染好的View实例
  6. 动画支持

更多实用功能,欢迎你来提出

项目成员

发起人

内部开发者

外部贡献者

等你加入

社区共建

DreamBox已经在滴滴顺风车的业务开发中落地支持了若干需求。我们在持续对框架进行新功能开发以及性能优化,希望能支持更多的场景。相对于远景目标,需要做的事情还有很多。

  • 如果你对本项目有兴趣,请不要吝惜你的star⭐️
  • 如果你想参与到项目的开发中来,欢迎向我们发起Pull Request
  • 任何问题(使用、原理、BUG等)欢迎向我们提交、与我们讨论,Issue和QQ群都是不错的沟通方式
  • 如果你的App采用了DreamBox,请让我们知道

QQ群

License

Copyright 2020 DiDi

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

More Repositories

1

DoKit

一款面向泛前端产品研发全生命周期的效率平台。
Java
20,108
star
2

cube-ui

🔶 A fantastic mobile ui lib implement by Vue
JavaScript
9,141
star
3

chameleon

🦎 一套代码运行多端,一端所见即多端所见
JavaScript
9,016
star
4

VirtualAPK

A powerful and lightweight plugin framework for Android
Java
8,979
star
5

LogicFlow

A flow chart editing framework focusing on business customization. 专注于业务自定义的流程图编辑框架,支持实现脑图、ER图、UML、工作流等各种图编辑场景。
TypeScript
8,315
star
6

KnowStreaming

一站式云原生实时流数据平台,通过0侵入、插件化构建企业级Kafka服务,极大降低操作、存储和管理实时流数据门槛
Java
6,941
star
7

booster

🚀Optimizer for mobile applications
Kotlin
4,866
star
8

nightingale

An enterprise-level cloud-native monitoring system, which can be used as drop-in replacement of Prometheus for alerting and management.
Go
4,510
star
9

mpx

Mpx,一款具有优秀开发体验和深度性能优化的增强型跨端小程序框架
JavaScript
3,619
star
10

mand-mobile

💰 A mobile UI toolkit, based on Vue.js 2, designed for financial scenarios.
Vue
3,454
star
11

sharingan

Sharingan(写轮眼)是一个基于golang的流量录制回放工具,适合项目重构、回归测试等。
Go
2,276
star
12

tinyid

ID Generator id生成器 分布式id生成系统,简单易用、高性能、高可用的id生成系统
Java
2,265
star
13

xiaoju-survey

XIAOJUSURVEY is an enterprises form builder and analytics platform that allows users to create questionnaires, exams, polls, quizzes, and analyze data online.
TypeScript
2,065
star
14

ChineseNLP

Datasets, SOTA results of every fields of Chinese NLP
HTML
1,783
star
15

DiDiPrism

小桔棱镜,一款专注移动端操作行为的利器! A powerful tool (iOS & Android) that focuses on mobile operation behavior!
Objective-C
1,716
star
16

gendry

a golang library for sql builder
Go
1,613
star
17

Hummer

一套移动端高性能高可用的动态化跨端开发框架
Objective-C
1,339
star
18

DDMQ

DDMQ is a distributed messaging product with low latency, high throughput and high availability.
Java
1,303
star
19

rdebug

Rdebug — Real Debugger
PHP
1,158
star
20

echo

Echo是一款桌面端调试工具,旨在提高客户端的研发调试效率
Objective-C
1,028
star
21

turbo

Turbo is a light-weight flow engine framework, support BPMN2.0. 一款轻量级流程引擎服务框架,可作为底层服务支持各类流程设计、低代码设计、工作流、审批流、服务编排等场景
Java
895
star
22

DroidAssist

A lightweight Android Studio gradle plugin based on Javassist for editing bytecode in Android.
Java
885
star
23

AoE

AoE (AI on Edge,终端智能,边缘计算) 是一个终端侧AI集成运行时环境 (IRE),帮助开发者提升效率。
C++
874
star
24

DRouter

Android Router Framework
Java
739
star
25

AgileTC

AgileTC is an agile test case management platform
JavaScript
673
star
26

falcon-log-agent

用于监控系统的日志采集agent,可无缝对接open-falcon
Go
583
star
27

super-jacoco

Java
473
star
28

epage

一款基于schema的低代码可视化页面配置工具
Vue
460
star
29

GateKeeper

A high-performance Golang gateway that supports rapid development and plug-inization
Go
436
star
30

sds

SDS是一个基于Java开发的简单、易用、高性能的服务降级系统,支持限流、熔断和降级等功能,服务端必备!!
Java
417
star
31

KnowSearch

面向Elasticsearch研发与运维人员,围绕集群、索引构建的零侵入、多租户的Elasticsearch GUI管控平台
Java
413
star
32

kemon

An Open-Source Pre and Post Callback-Based Framework for macOS Kernel Monitoring.
C
373
star
33

di18n

一种自动转换、基于配置的前端国际化方案
JavaScript
305
star
34

pile.js

pile.js components build with React.
CSS
267
star
35

ES-Fastloader

Quickly build large-scale ElasticSearch indices by using the fault tolerance and parallelism of Hadoop
Java
265
star
36

KnowAgent

基于日志模板构建,采集任务动态管控、数据质量精确度量,一站式日志采集平台
Java
255
star
37

Unify

An efficient, flexible Flutter-Native hybrid communication framework for seamless module integration and automatic code generation.
Dart
255
star
38

LogiCommon

Java版 认证、鉴权、管理、任务调度通用功能组件
Java
218
star
39

Tips

JavaScript
187
star
40

maskdetection

C++
179
star
41

dlflow

DLFlow is a deep learning framework.
Python
157
star
42

didi.github.io

didi website
HTML
143
star
43

hetsann

Source Codes of HetSANN in the AAAI'20 paper: An Attention-based Graph Nerual Network for Heterogeneous Structural Learning.
Python
142
star
44

collection

go collection package for fasting coding
Go
127
star
45

athena

A release version for https://github.com/athena-team/athena
Python
124
star
46

JuShaTa

JuShaTa是一个Java容器,提供模块隔离及模块热加载能力。
Java
121
star
47

logbook

Java
107
star
48

heteta

HetETA: Heterogeneous Information Network Embedding for Estimating Time of Arrival
Python
105
star
49

levin

A Quick Way to Bulk Loading
C++
105
star
50

TrafficIndex

TTI ,Smart Transportation Industry Standard
C++
94
star
51

thrift-mock

A lightweight java test library for mocking thrift server
Java
92
star
52

mand-mobile-rn

💰 Mand Mobile for React Native, designed for financial scenarios.
TypeScript
88
star
53

vue-tmap

一个基于腾讯地图JavaScript API GL、TypeScript 封装适用于 Vue3 的高性能地图组件库
TypeScript
88
star
54

slime-validator

JavaScript library of validation based on Plugin system and make data validation be easy.
JavaScript
85
star
55

mtmc-vt

MTMC Vehicle Tracking For AI City challenge 2019
Jupyter Notebook
70
star
56

FeatureProbe

开源的高效可视化『功能』管理平台,提供灰度发布、AB实验、配置变更全功能。
66
star
57

sgt

didiyun super-agent daemon
Go
58
star
58

ALITA

ALITA is a layer-based data analysis tool. The front-end see
Java
51
star
59

react-tmap

一个基于腾讯地图JavaScript API GL、TypeScript 封装适用于 react 的高性能地图组件库
TypeScript
48
star
60

benchmark-thrift

An open source application designed to load test Thrift applications
Java
45
star
61

elastic-trib

elasticsearch cluster command line tool.
Go
39
star
62

mpx-cube-ui

基于"Mpx 小程序框架"的移动端基础组件库
TypeScript
27
star
63

yarc

基于 eBPF 的流量录制工具
C
26
star
64

tg-flow

Go
24
star
65

paladin

Scala
20
star
66

MEEP

End-to-end framework to build automatic agents (chatbots) for task-oriented dialogs
Python
18
star
67

WorkTrans

Python
15
star
68

ALITA_UI

ALITA is a layer-based data analysis tool. The back-end see
JavaScript
13
star
69

wmt2021_triangular_mt

The baseline model code for WMT 2021 Triangular MT
Python
13
star
70

MeetDot

Python
12
star
71

DAIBench

Shell
10
star
72

didi-tech-edu

9
star
73

daedalus

JavaScript
7
star
74

tmap-types

腾讯地图 js api 类型声明,主要用于 react-tmap 和 vue-tmap 组件库
5
star
75

Json-adapter

Java
3
star