Tangram
模型目前已在手机天猫 & 淘宝 Android 版内广泛使用
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1BuGTVOn-1650983084934)(//upload-images.jianshu.io/upload_images/944365-de4973c49886aae1.png?imageMogr2/auto-orient/strip|imageView2/2/w/1200/format/webp)]
在性能方面,希望 贴近Native开发,重点:页面渲染效率 & 组件回收复用
VLayout
和 LazyScroll
两个基础组件,通过一个双索引可见区域组件发现算法,实现了跨父节点组件的高效回收和复用。根据 业务类型 将组件 封装成 能承担一定业务能力的复用单元。
如一种瀑布流布局
提供 控制台 让业务方可直接控制基于Tangram的产品,如调整页面布局,切换页面数据等。
- 即 页面的排版布局 可 通过后端数据的下发来动态调整
- 服务网关的建设目标是最大程度的降低业务创建Tangram页面的压力和成本。
但这种动态化 是 面向粗粒度组件:通过 布局+组件的形式搭建整个页面,而不是一般从 **基本的UI元素(如按钮blabla)**搭建页面。
- 其实也很好理解,业务人员需要用到的是 能承担一定业务能力的“业务布局”,而不是单一UI元素(按钮、文本blabla)
- 好处:使用成本低,上线周期短
采用插件化扩展
内部本来就注册在框架里 & 外部也可注入扩展模块
对于业务开发,存在多端表现不一致的问题。为了解决该问题,以前需要通过复杂的网关逻辑来兼容多端逻辑不一致情况。
为了防止该问题,对于Tangram,预先制定了两个开发原则:
Tangram
的架构主要由三部分组成:Tangram SDK
Tangram AC
Tangram OP
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tDmi5FcY-1650983084935)(//upload-images.jianshu.io/upload_images/944365-b2f0d39a3d0bc121.png?imageMogr2/auto-orient/strip|imageView2/2/w/1092/format/webp)]
本文主要讲解的是用于客户端页面渲染的Tangram SDK
。
在讲解架构前,我们需要先了解Tangram
的一些模型知识。
一个页面实体由3部分组成:页面(Page)、卡片(Card) & 组件(Item)
具体如下图:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aLhzAkx5-1650983084935)(//upload-images.jianshu.io/upload_images/944365-eb 《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》无偿开源 徽信搜索公众号【编程进阶路】 7c5d4acab30ace.png?imageMogr2/auto-orient/strip|imageView2/2/w/680/format/webp)]
之间的关系:组件 构成 卡片、卡片 构成 页面。
对于Tangram
,他的页面概念模型可用 树状模型(3层结构) 表示:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ecQRRA0n-1650983084937)(//upload-images.jianshu.io/upload_images/944365-cdfc8fa53eabdeb3.png?imageMogr2/auto-orient/strip|imageView2/2/w/580/format/webp)]
下面主要讲解 三层结构中 的 卡片 & 组件。
- 即对组件进行 组合 & 布局
- 只声明布局方式,不提供布局细节
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dhKmJPB9-1650983084938)(//upload-images.jianshu.io/upload_images/944365-06b12ff779f31cf9.png?imageMogr2/auto-orient/strip|imageView2/2/w/1200/format/webp)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FCWgdoo8-1650983084940)(//upload-images.jianshu.io/upload_images/944365-b4b06b15e1f8168a.png?imageMogr2/auto-orient/strip|imageView2/2/w/1200/format/webp)]
关于四个部分的细节,我将在Tangram具体使用时进行介绍
日常使用的普通的
View
,如按钮、图片等等
作用:负责UI元素展示 & 业务逻辑
组成元素:视图模型(ViewModel
) & 样式(Style
)
视图模型:所有组件对有一个统一视图模型(ViewModel
),主要是定义了生命周期事件:
init()
bind()
unbind()
关于 组件的基本样式 主要包括:组件背景、外边距、内边距、组件的宽高比等等。具体细节会在具体使用时介绍。
Tangram
的结构主要由5部分组成,如下图:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2s0OQnJR-1650983084941)(//upload-images.jianshu.io/upload_images/944365-b62ac1e5e10a5890.png?imageMogr2/auto-orient/strip|imageView2/2/w/1200/format/webp)]
当页面数据传入时:
- 解析过程会根据之前注册过的卡片、组件类型来解析
- 未定义的数据将会被抛弃
- 布局框架 根据卡片提供的布局信息进行布局
- 布局框架 根据组件提供的组件信息获取组件实例,布局到布局容器里
Tangram
的核心功能Tangram
采用 插件化形式 进行扩展:[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2ZW6N7XJ-1650983084941)(//upload-images.jianshu.io/upload_images/944365-11adc46f3a47c15c.png?imageMogr2/auto-orient/strip|imageView2/2/w/1200/format/webp)]
展模块
Tangram
的核心功能Tangram
采用 插件化形式 进行扩展:[外链图片转存中…(img-2ZW6N7XJ-1650983084941)]