淘宝客户端动态化页面搭建(淘宝客户端动态化页面搭建方案)
ann3311 2025-04-05 16:30 5 浏览 0 评论
详情客户端团队 大淘宝技术
2025年03月28日 15:07 浙江
在手机淘宝等高频更新的业务场景中,UI页面的动态化和快速交付成为技术团队面临的重要挑战。本文围绕“客户端动态化页面搭建”这一主题,深入探讨了如何通过抽象框架设计解决高动态化页面的快速构建问题。文章详细介绍了框架的核心模块(如DataEngine、LayoutEngine、StateCenter等)、页面动态性实现方式、组件通信机制以及业务接入流程,并结合实际案例分析了布局方式多样性的问题及解决方案。最终总结了该框架在动态性、拓展性和能力沉淀方面的优势,为类似业务场景提供了宝贵的实践经验。
背景
手机淘宝详情一直是一个页面UI更新频率较高的业务场景,对于UI元素变更有快速交付的要求。接手行业相关的需求后,发现行业相关的UI更是如此,行业每个业务UI各不一样,但布局逻辑大致相同。针对上述背景,我们希望能有一个对于高动态化页面快速搭建的解决方案。
问题
当业务由于某些原因需要对渲染协议进行升级的时候,端侧就会产生一个全新的版本,比如详情1.0、2.0、行业化等等。虽然页面整体布局方式大致一致,但是各个版本之间的代码基本是割裂的,如果需要升级协议,每次的工作量都是巨大,而且切流过程也是比较复杂。
框架设计
为了解决这个问题,我们对整体页面的搭建抽象了一套框架,架构图如下:
数据协议层:
业务定义一套固定的渲染协议和模型,用于抹平不同场景下服务端数据协议格式不一致的问题。各个业务按照模型完成数据协议到渲染协议的转换。
基础组件:
包括Native组件、DX组件、Weex组件、H5组件,其中DX和Weex为淘宝内的UI跨端组件。
页面容器层:
容器提供一套标准的api用于业务能力注入,包括:生命周期、数据访问、能力调用、状态管理、消息处理、组件发现、监控上报、日志打印。
- 整体流程
- 服务端下发协议内容,通过解析转换成渲染数据模型Model,存放在DataEngine中,渲染数据模型中包括所有需要渲染的UI数据信息,具体的模型数据结构由业务方自己定义
- 业务对整个渲染数据模型进行解析,生成所有需要渲染的组件Component列表,解析完成后的组件信息将会存放在ComponentManager中
- LayoutEngine负责对所有组件Component进行布局,例如详情的布局是RecyclerLayout形式,行业布局是Z轴叠加的形式
基于页面性能与交付效率考虑,淘宝详情页面大多由个DX组件组成,部分复杂度较高的组件则通过native实现,页面整体布局信息通过服务端协议下发。
- 页面动态性
页面的动态性通过渲染数据修改和组件动态更新保证
- 通过往数据模型中 增/删/改 组件Component数据,完成页面上组件的 增/删/改
- 通过对组件本身的更新,例如升级DX、Weex等,更新对应的组件
- 页渲染模型和渲染流程解耦
如果需要升级渲染协议、不修改页面布局方式,只需要修改渲染模型,同时调整业务侧解析渲染模型的逻辑即可。
如果想复用渲染协议,但是自己定制布局方式,那只需要自己定制LayoutEngine的实现即可(当前天猫,飞猪等接入手机淘宝详情方式)
- 页面生命周期
业务可以通过
LifecycleManager.registerLifecycle注册页面的生命周期监听器,对外暴露的生命周期包括系统生命周期(Android onCreate/onDestroy,iOS didAppear/disAppear等),以及自定义的一些页面生命周期切面,比如网络请求、数据处理、预加载等切面
- 组件通信
框架通过EventCenter进行消息通信,通过
EventCenter.registerListener注册消息接收器,通过EventCenter.postEvent发送消息。
- 组件状态同步
组件之间状态同步通过StateCenter进行同步,页面级别的所有核心状态都通过StateCenter进行管理,各个组件可以通过
StateCenter.setState/getState进行State属性值的设置和获取。组件也可以通过
StateCenter.registerStateChangeListener对属性值的变化注册监听器,以此达到多个组件之间的状态同步。
伪代码:
Component1: StateCenter.registerStateChanged("A", listener)
Component2: StateCenter.setState("A", newValue)
Component1: listener.onStateChanged("A", oldValue, newValue)
- 能力沉淀
对于业务需要用到的一些标准能力,我们统一封装成Ability后,统一由AbilityCenter进行管理。
Ability可以包括业务强相关的,比如详情中sku、浮层相关,也可以对接Megability,AK等平台。
- 框架上下文
上下文对象为TBIContext,上述提到的EventCenter、StateCenter、AbilityCenter、LifecycleManager、LayoutEngine、ComponentManager、DataEngine都统一封装在TBIContext中。除了上述对象外,还提供统一的监控工具Monitor和日志工具Log,以及系统级别的上下文对象(Android Context,iOS VC)。
- 业务接入
业务接入主要有四个步骤
1.实现DataEngine,这一步主要需要确定好自己的渲染协议,并将协议格式具象化为一个渲染模型Model,同时实现服务端协议数据转译为渲染模型Model对象逻辑。
2.实现LayoutEngine布局逻辑,完成自己页面的UI布局
3.实现业务的逻辑Biz类,实现方法:
a.requestData 必须,业务数据获取逻辑
b.parseComponents 必须,翻译渲染模型,生成Component列表
c.preload 非必须,预加载
4.注入Biz实现到PageManager
- 流程串联
PageManager负责整体的流程串联,将业务Biz的逻辑和整体页面生命周期结合起来,实现一套完整的流程,整体流程的时序图如下:
- 问题回顾
如何解决布局方式多样性的问题
1.渲染协议定义布局方式,覆盖大部分的通用布局方式
最开始的讨论方向是怎么通过一个协议结局所有的布局问题,都在往整个协议怎么设计能够满足需求的方向走。后来讨论下来发现如果要做到我们想要的效果,基本需要自己实现一套html+css的解析器,整体工作量大,实现细节复杂,后续维护起来比较困难。而且由于需要携带的信息变多,协议包大小也会有所增加。同时考虑到业务的布局信息在很大一个时间段内基本不会有太大的变动,整体roi比较低。
2.业务场景下固定布局
这种方式下,协议只需要携带所有的组件信息,不需要描述太多布局数据,数据包大小有所优化。布局逻辑相对也比较简单纯粹。同时动态性也可以通过服务端协议组件数据调整以及DX、WEEX本身动态能力有所保障。
缺点在于如果需要对布局方式修改,需要端侧重新发版。但是考虑到布局方式变动频率很低,其实也可以接受。
总结
本套框架主要目的是解决动态页面的快速搭建问题,具有以下特点:
- 在UI页面上具有一定的动态性
- 具有一定的拓展性,支持不同的业务快速接入,目前手机淘宝详情和行业相关的一些业务都是这套框架
- 通用基础能力沉淀,可以直接对接Mega和AbilityKit,也可以对业务常用的一些能力进行沉淀
团队介绍
我们是淘天集团详情客户端团队。作为淘宝流量规模最大的核心业务,我们立足于导购链路的终端节点与交易场景的初始入口,始终致力于构建行业领先的详情业务平台。通过技术深度沉淀与细节持续优化,我们不断提升业务系统的流畅度,完善产品功能细节,为用户提供更优质、更沉浸的购物体验。
相关推荐
- 淘宝内测新版店铺会员表达体系:首页新增会员日飘条,搜索及推荐加强露出
-
记者获悉,淘宝近日已开始向部分用户内测新版店铺会员表达体系。参加内测的用户发现,淘宝首页上方已新增会员日飘条,店铺会员相关活动和信息开始集中出现在搜索、推荐、商品详情页等多个重要场域。具体而言,目前店...
- 淘宝活动海报尺寸多少?首页活动怎么设置?
-
当淘宝活动设置好了以后,必须要进行宣传,很多商家会在淘宝店铺首页设置一下相关的活动,这样用户进入店铺就能看到了,那么首页活动应该怎么设置?下面我们一起来具体了解看看吧。淘宝首页活动怎么设置?打开千牛客...
- 淘宝大学首次跨界携手TCL成立新零售学院
-
e公司讯,e公司记者从TCL集团获悉,1月26日,阿里巴巴集团旗下培训平台淘宝大学首次跨界携手TCL成立淘宝大学·TCL新零售学院。该新零售学院将设立在TCL酷友网络科技有限公司,以虚拟学院形式运作。...
- 淘宝大学认证讲师田野:十年天猫双11唯一没变的就是变化
-
田野封面新闻记者易弋力他是最早一批参加双11的商家,开业三天的店铺在第一个双11赚了39万;他是淘宝大学8年的王牌讲师,练就了看一眼首页就知道店铺转化率的“北冥神功”。他就是双11的十年“老司机”—...
- “聚焦食品电商 勇抓蜀商机遇”,淘宝大学川渝食品商家赋能公开课今日开讲
-
6月15日,由淘宝大学和淘宝汇吃主办,封面新闻承办的“聚焦食品电商勇抓蜀商机遇”川渝食品类商家赋能活动暨19财年食品与汇吃商家大会在成都举行。这是自今年3月27日淘宝大学华西分校成立以来的首次垂直领...
- 淘宝大学电商直播西南分校落户重庆
-
阿里巴巴联手重报集团培养直播带货达人重庆日报讯(记者王丽)6月15日,阿里巴巴集团与重庆日报报业集团在渝举行“淘宝大学电商直播西南分校”签约揭牌仪式,阿里巴巴淘宝大学在西南地区唯一一所电商直播培训...
- ◎ 淘宝大学培训农村电商“店小二”
-
息烽区位优势明显,发展潜力巨大。县委、县政府经过仔细分析,决定借贵州发展大数据之机,大力发展农村电商,带动县域经济发展。但是电商专业人才紧缺,物流成本高,让多数息烽特色商品在大山中“沉睡”……困难面...
- 转化率低?无线端详情页该这么做| 网商大学
-
文/蛋蛋无线详情页优化可谓是无线转化的重中之重。商家都意识到无线详情优化非常重要,都开始重视并去做。可是还有不少商家的无线转化不好,只因详情页制作没有注意到设备特征。以网商大学诊断的一家时尚女装品...
- 想成为电商人才吗 快去淘宝大学贵阳分校吧
-
3月25日上午,淘宝大学贵阳分校在清镇淘宝生态城挂牌成立。创业者可免费进校受训,淘宝生态城将提供培训、店铺、供货、销售等创业条件,创业者在淘宝城可实现白手创业当电商老板。据悉,淘宝大学今后计划免费培训...
- 报名速来~淘宝大学沭阳培训基地新一期课程上线!
-
提示:点击上方"太原易点微信"↑免费订阅本刊大家注意啦~~~淘宝大学沭阳培训基地2018年度第十一期培训课程来啦本次淘大的讲师想必大家都熟悉——孙瑜,有“搜索大神”之称他的课场场爆满,还不赶快来报名~...
- 淘宝大学要开“无线”学科,课程设置看起来很实用
-
淘宝大学负责人叶挺口述:淘宝大学负责人叶挺整理:范婷婷应阿里今年的无线升级和赋能商家战略,阿里巴巴商家事业部、淘宝大学推出了2016官方全新培训项目——“网商成长三板斧”,培训内容紧贴当前最新的...
- 还在纠结“双十一”该怎么玩?淘宝大学“特训”来帮你!
-
提示:点击上方"沭阳发布"↑快来关注我们!一年一度的双十一购物狂欢节即将来临!“野心勃勃”的卖家们已开始摩拳擦掌为赚得盆满钵满积极应战!今日,电子商务“双十一”专场培训开班!吸引了来自县内外530余名...
- 今天开始,淘宝可以微信支付了(今天开始,淘宝可以微信支付了吗)
-
9月5日,淘宝网发布公告,宣布新增微信支付能力:为提升消费者的购物体验,淘宝网计划新增微信支付能力,于本公告公示七天后逐步向所有淘宝网卖家开放。2024年9月12日生效,也就是今日开始生效。基于上述服...
- 冲上热搜!淘宝将可用微信支付?网友:赶紧的吧
-
今天,微博话题“淘宝即将全面支持微信支付”冲上热搜榜首,引发公众关注。9月4日,淘宝天猫发布公告称,为提升消费者购物体验,淘宝计划新增微信支付能力,并于本意见征集结束后,进行平台规则调整。据悉,本次调...
- 12日起,淘宝可用微信支付了(淘宝是否可用微信支付)
-
淘宝发布关于《新增微信支付能力的公告》公示7天后,在12日起逐步向所有淘宝网卖家开放。9月5日,淘宝网发布公告,宣布新增微信支付能力:为提升消费者的购物体验,淘宝网计划新增微信支付能力,于本公告公示七...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 淘宝店铺优惠券怎么用 (36)
- 淘宝图片上传 (53)
- 购买天猫专卖店 (31)
- 淘宝搭配套餐怎么弄 (31)
- 淘宝试用什么意思 (39)
- 淘宝动态评分 (34)
- 淘宝保证金在哪里交 (32)
- 淘宝宝贝降权 (32)
- 淘宝恶意点击 (32)
- 淘宝查号 (31)
- 淘宝系统异常 (31)
- 天猫平台 (33)
- 淘宝信誉等级划分 (31)
- 天猫网店开店费用 (32)
- 淘宝假一赔三申请 (37)
- 淘宝会员打折 (35)
- 淘宝好评率 (32)
- 淘宝如何加入购物车 (33)
- 淘宝涨价 (35)
- 淘宝如何刷信誉 (32)
- 天猫直播入口 (34)
- 淘宝上架 (33)
- 淘宝帐号 (33)
- 淘宝不能发货 (33)
- 淘宝排名查询 (32)