天猫逆向交易Java面试_简单逆向天猫的思考

多Tab应用App使用中,第一个实质页面的呈现速度和操作体验,极大影响了用户使用欲望和整体评价。对于电商App而言,首页更直接关联商品推介和订单转化。所有页面中,首页使用频率最高,停留时间最长,极致优化良好布局App首页是收益极高的任务。

笔者从UI和代码等多切点分析天猫iPhone App首页,在一定程度内复现编码逻辑 。使用了网络抓包、沙盒目录分析、reveal 视图层次、dump类头文件、IDA内存寻址、LLDB越狱联调等方式,将获得信息简单筛选梳理,希望能对应用开发的童鞋有稍许帮助或者参考意义。

一、架构级服务支持

1.图片缓存,全权托管SDWebImageCache。SDWebImageCache在体验和性能上都有很好的优化,并得到长期开源维护。

2.HotFix,使用了服务器下发JSPatch文件的方式,但不依赖JSPatch三方库。JSPatch大约1600行OC和90行JS代码,提供了核心功能。

3.Hybrid,预加载H5全站至沙盒,从而能快速从Native切换至WebApp,在重大活动时可以实时监控和维护界面而不至Crash。

4.营销支持,每个顶级Native View所在VC,均在屏幕外实例化WVWebView(计划替换UCWebView中),以执行类似红包雨等营销活动。

5.数据本地持久化,切合Cache、Perference、Library、tmp、Document各沙盒目录特性。

二、数据源策略对用户体验的影响

先以这样一个前提条件为基础:首页的布局变动需要经过市场调研,给出充足理由;否则在很长一段时间内,首页的布局都是轻微或者基本不变化的。

从这个前提出发,天锚首页采用了这样的策略:1.用户新安装App时有预置数据;2.优先本地数据实例化UI组件和初步绘制;3.服务器数据到达后重新绘制;4.完成一次服务器请求,变动的布局文件被持久化,以供下次打开时用最新布局;5.由于新布局可能在灰度测试中,新布局不一定存放至持久化存储位置(NCPersitentxxx),但会存到至另外一处(Preference)并优先使用。

首页的绘制降低对服务器数据返回的必然依赖,是目前大部分流行App的数据绘制选择。有这样几个好处:1.增加信息推介机会。用户在断网情况下也能浏览主页,至少能浏览商品目录树,如有图片缓存可获更多信息; 2.优化界面呈现速度。等待网络过程中,可以完成所有对象的实例化与绘制(天猫首页并没有重用此时实例化的对象或绘制,在网络数据返回后,将重复一遍实例化和绘制过程。但各实例有canReuse属性以支持重用);3.提高用户体验。不需要在首页弹出交互打断的AlertController,实际上大部分App断网时不会在首页弹出Alert或只有空白页。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值