Android Tangram模型:连淘宝、天猫都在用的UI框架模型你一定要懂

前言

  • Tangram 是阿里出品、用于快速实现组合布局的框架模型,在手机天猫 Android & iOS版 内广泛使用

  • 今天我将对Tangram 模型 进行全面介绍,希望你们会喜欢。


目录


1. 为什么要使用 Tangram 模型

在讲解 Tangram模型 前,我们先来搞懂一个问题:为什么要使用 Tangram模型

1.1 背景

  • 技术 是用于 满足需求业务 的 解决方案,现有的需求业务可分为三类:基础业务、常规业务 & 临时性任务。具体细节如下:

1.2 问题

相应的解决方案的特点如下:

  • 对于基础业务,采用 Native 的方案,不作过多解释
  • 对于临时性业务,随着WebView性能的提升 和 移动端设备硬件的发展,现阶段 HTML 加载速度 & 渲染速度慢的缺点将会逐渐被完善,对于临时性业务的需求能够满足

但对于常规业务,至今还没盖棺定论的方案,所以才会存在两种方案:WebView+HTML & Dynative方案。但这两种方案是存在问题的:

  1. WebView+HTML方案:随着WebView性能的提升 和 移动端设备硬件的发展,HTML加载速度 & 渲染速度慢的缺点将会逐渐被完善,所以常规业务需要的性能还是难以满足。
  2. Dynative(如RNWeex):虽然性能能满足,但由于该技术还不成熟,稳定性差,且开发难度大,所以对于常规业务还是非常谨慎的使用。

1.3 解决方案

Tangram 正是解决 常规业务 的方案:在性能、稳定性 & 开发周期 取得较好平衡的一种折中方案。


2. 定义

  • 是一种用于快速实现组合布局的框架模型

    1. 所谓概念模型,即只停留在定性分析的解决方案 & 思路,还未真正具体实现
    2. Tangram的具体实现是一种 NativeiOS & Android)的快速实现 组合布局 的界面开发框架,下面会详细说明
  • 中文即七巧板,即该框架 提供一系列基本单元布局,通过快速拼装就能搭建出一个具备多种布局的页面

    就像使用七巧板 通过现有板块 快速拼凑出 多样的形状一样。


3. 应用场景

  • 常规业务 中 复杂的布局格式混排,如:浮动布局、栏格布局、通栏布局、一拖N布局、瀑布流布局,还可以组合使用这些布局
  • 具体场景是:如电商平台首页、活动频道等等

    Tangram 模型目前已在手机天猫 & 淘宝 Android 版内广泛使用


4. Tangram优点

4.1 高性能

在性能方面,希望 贴近Native开发,重点:页面渲染效率 & 组件回收复用

  • 页面渲染:为了提升渲染效率,Tangram将在视图渲染之前把大量的计算工作在VM中完成,并缓存在VM组成的树形结构里。
  • 回收和复用——Tangram在Android和iOS平台上分别开发了VLayoutLazyScroll两个基础组件,通过一个双索引可见区域组件发现算法,实现了跨父节点组件的高效回收和复用。

4.2 面向业务

a. 组件业务化

根据 业务类型 将组件 封装成 能承担一定业务能力的复用单元。

如一种瀑布流布局

b. 动态化

提供 控制台 让业务方可直接控制基于Tangram的产品,如调整页面布局,切换页面数据等。

  1. 即 页面的排版布局 可 通过后端数据的下发来动态调整
  2. 服务网关的建设目标是最大程度的降低业务创建Tangram页面的压力和成本。

但这种动态化 是 面向粗粒度组件:通过 布局+组件的形式搭建整个页面,而不是一般从 基本的UI元素(如按钮blabla)搭建页面。

  1. 其实也很好理解,业务人员需要用到的是 能承担一定业务能力的“业务布局”,而不是单一UI元素(按钮、文本blabla)
  2. 好处:使用成本低,上线周期短

4.3 扩展性好

采用插件化扩展

内部本来就注册在框架里 & 外部也可注入扩展模块

4.4 多端一致性

对于业务开发,存在多端表现不一致的问题。为了解决该问题,以前需要通过复杂的网关逻辑来兼容多端逻辑不一致情况。

为了防止该问题,对于Tangram,预先制定了两个开发原则:

  1. 任意新功能的提出都是不区分平台,在功能设计中必须同时考虑多端功能,具体的实现方案和逻辑必须多端统一Review以保证多端表现一致。
  2. 任意一端的变更都必须在改动前把方案同步给其他端,而且变更必须多端同步发布。

5. 架构 & 原理讲解

  • Tangram的架构主要由三部分组成:

    1. Tangram SDK
    2. Tangram AC
    3. Tangram OP
  • 每部分的具体细节如下:

本文主要讲解的是用于客户端页面渲染的Tangram SDK

5.1 知识储备

在讲解架构前,我们需要先了解Tangram的一些模型知识。

a. 页面概念模型
  • 一个页面实体由3部分组成:页面(Page)、卡片(Card) & 组件(Item)
  • 具体如下图:

  • 之间的关系:组件 构成 卡片、卡片 构成 页面。
  • 对于Tangram,他的页面概念模型可用 树状模型(3层结构) 表示:

下面主要讲解 三层结构中 的 卡片 & 组件。

b. 卡片
  • 作用:负责布局逻辑

    1. 即对组件进行 组合 & 布局
    2. 只声明布局方式,不提供布局细节
  • 组成

    卡片由有四部分组成:header、footer、body、style

关于四个部分的细节,我将在Tangram具体使用时进行介绍

c. 组件
  • 定义:最小单位的UI元素

    日常使用的普通的View,如按钮、图片等等

  • 作用:负责UI元素展示 & 业务逻辑
  • 组成元素:视图模型(ViewModel) & 样式(Style

视图模型:所有组件对有一个统一视图模型(ViewModel),主要是定义了生命周期事件:

  • 组件初始化时会调用init()
  • 滑入屏幕绑定数据时,调用bind()
  • 滑出屏幕解除绑定时,调用unbind()

关于 组件的基本样式 主要包括:组件背景、外边距、内边距、组件的宽高比等等。具体细节会在具体使用时介绍。


5.2 Tangram结构

Tangram的结构主要由5部分组成,如下图:

5.3 原理解析

当页面数据传入时:

  • 核心引擎调用 数据解析器 将 数据 转换成卡片和组件对象

    1. 解析过程会根据之前注册过的卡片、组件类型来解析
    2. 未定义的数据将会被抛弃
  • 数据解析器将解析完毕的卡片、组件对象传递给布局框架,进行页面渲染。
    1. 布局框架 根据卡片提供的布局信息进行布局
    2. 布局框架 根据组件提供的组件信息获取组件实例,布局到布局容器里

6. 扩展模块

  • 上面介绍的内容里是Tangram的核心功能
  • 但当需要落实到具体业务,仅仅该核心功能是无法满足的,还需要很多辅助、扩展的功能
  • Tangram 采用 插件化形式 进行扩展:


7. 具体使用

8. 总结


请帮顶或评论点赞!因为你的鼓励是我写作的最大动力!



参考文章:

1. http://pingguohe.net/2017/03/30/what-is-tangram.html

2. http://pingguohe.net/2016/12/20/Tangram-design-and-practice.html?from=timeline

3. http://pingguohe.net/2017/04/24/tangram-1.0.html?from=timeline

时间: 2024-12-16 04:26:03

Android Tangram模型:连淘宝、天猫都在用的UI框架模型你一定要懂的相关文章

V - Layout:淘宝、天猫都在用的UI框架,赶紧用起来吧!

前言 V- Layout 是阿里出品的基础 UI 框架,用于快速实现页面的复杂布局,在手机天猫 Android版 内广泛使用 让人激动的是,在上个月V- Layout终于在Github上开源! Github - alibaba - vlayout 在五一假期我对V- Layout进行了详细分析,我将献上一份 V- Layout的使用攻略 & 源码分析,希望你们会喜欢. 目录 1. 为什么要使用 V - Layout 在讲解 `V - Layout` 前,我们先来搞懂一个问题:为什么要使用 `V

淘宝天猫关键词SEO优化

淘宝天猫的网站完全像是一个成熟的搜索引擎,只是从google.bing.baidu改成了淘宝天猫而已,普通搜索引擎有品专,有皇冠,有PC,有无线:淘宝天猫里面有钻展,有直通车,也有PC,无线.搜索引擎是依靠竞价和热度来排名的,但是淘宝天猫却是完全依靠热度在排名,打开淘宝天猫的页面可以看到: 商品根据搜索关键词来进行展现,但是排序方式有这几种: 1.综合排序 2.人气排序 3.销量排序 4.信用排序 5.价格排序 系统默认的排序是综合排序,在其他情况不变的情况下,怎么通过优化关键词来将排名靠前呢?

Python网页信息采集:使用PhantomJS采集淘宝天猫商品内容

1,引言 最近一直在看Scrapy 爬虫框架,并尝试使用Scrapy框架写一个可以实现网页信息采集的简单的小程序.尝试过程中遇到了很多小问题,希望大家多多指教. 本文主要介绍如何使用Scrapy结合PhantomJS采集天猫商品内容,文中自定义了一个DOWNLOADER_MIDDLEWARES,用来采集需要加载js的动态网页内容.看了很多介绍DOWNLOADER_MIDDLEWARES资料,总结来说就是使用简单,但会阻塞框架,所以性能方面不佳.一些资料中提到了自定义DOWNLOADER_HAND

淘宝天猫致敬9大年度人物:第一个穿打底裤的男人上榜

12 月 30 日,淘宝天猫宣布致敬 9 大年度人物.这些人物"画风"各异,但每个人都在给世界带来微小而美好的改变:<strong>第一个穿打底裤的男人.在直播间买空贫困县的"所有女生".把汉服"穿成"百亿大市场的 90 后们.开始学着说"OMG!拍它拍它"的法官……</strong> 淘宝天猫相关负责人表示:"从这一年涌现的人物中,我们可以看到 2019 年中国社会其实出现了很多新的变化.不

淘宝天猫店如何做运营?看完这个思维导图你就知道了!

自2003年成立的淘宝网,时至今日已有16年了.在这一十六年的时间里,淘宝这一网络购物平台见证了许多起起伏伏,有人通过努力拼搏.正确的经营方法,获得了成功,但是同样也有人因为经营不善.错误的营销方式只能无奈黯然退场.但当时的他们都是在摸着石头过河,并不能像我们一样进行回望判断. 而今天的我们如果想要在淘宝这一平台上获得成功,已经不必像那些前辈一样摸着石头过河了.我们可以去参考许多前辈积累下的经验,尤其是那些在淘宝这一购物平台上获得成功的前辈高人们的经验. 今天为大家推介的这一本书--<淘宝天猫店

Python3中级玩家:淘宝天猫商品搜索爬虫自动化工具(第一篇)

Python3中级玩家:淘宝天猫商品搜索爬虫自动化工具(第一篇) 一.前言 大家好,今天我要来讲讲一个比较实用的爬虫工具,抓取淘宝的关键字商品信息,即是: 输入关键字,按照价格等排序,抓取列出的商品信息以及下载图片,并且支持导出为Excel. 如果如下: 看完下面的讲解,Python语言就掌握得差不多,中级水平了,而且这个封装后的工具还是很好用的. 感觉自己萌萌哒~~ 二.原理 大家知道什么叫爬虫,它也叫网络蜘蛛,机器人等,意思就是说自动的程序,可以去抓取使用网络协议传输的内容. 目前来讲爬虫主

Mac 无法打开淘宝,天猫,京东等

我的Mac Pro是新本,一直打不开淘宝,天猫,京东等购物网站,查了一下是DNS的问题,我把原有的DNS改成114.114.114.114,然后打开以上网页的速度就飞起来了. 修改DNS的步骤如下: 1.打开"系统偏好设置" 2.点击"网络" 3.点击"高级" 4.按照以下序号进行操作: 1.点击标号1位置DNS,如果3区域有内容,则全部选中然后点击标号2旁边的"-"(减号)删除 2.如果标号3区域无内容则直接点击"

@半条_虫 淘宝天猫自动批量打旗帜插件,精准打旗解放双手

/* * * 淘宝天猫批量打旗帜工具 Beta 1.0.0.0 * Release date: * Author : 半条虫(466814195) * Keywords : Etsoftware 半条虫(466814195) rimke 39doo 39度 * Description : 本脚本功能由EtSoftWare团队研发,仅供学习不得用于商业用途. * Blog : http://rimke.blog.163.com/ * Website : http://www.39doo.com/

android版高仿淘宝客户端源码V2.3

android版高仿淘宝客户端源码V2.3,这个版本我已经更新到2.3了,源码也上传到源码天堂那里了,大家可以看一下吧,该应用实现了我们常用的购物功能了,也就是在手机上进行网购的流程的,如查看产品(浏览),下订单,进行付款等流程,该应用一一实现了,同时还可以远程读取图片功能,和实时监控网络状态等操作,大家如果有什么不同的意见可以留下,我们会定时来查看. 原文地址:http://www.cnblogs.com/androidioscom/p/3613035.html [1].[代码] [Java]