Weex在内涵发现页中的工程实践

React-Native和Weex是目前最为火热的两个客户端跨平台解决方案。从去年2016年9月份开始,IES在抖音产品中应用了React Native,中途遇到了很多的问题,尤其是长列表的性能问题一直没能从根本上得到解决。

鉴于Weex在性能方面做过一些针对性的优化并且已在阿里的业务线上得到了规模性的应用,我们决定在内涵段子这个具备800万日活的产品中尝试应用Weex。这样做的主要目的是为了深化对Weex的认识,与React Native进行对比分析,确立IES客户端跨平台方案的下一步研究方向。

一、工程实践

1.1 准备工作

1.2 调试

1.2.1 调试环境

在Weex项目中,调试代码的环境有三种:浏览器、Weex Playground APP、自己的应用内。

因为Weex的代码可以同时兼容浏览器、iOS和安卓三种运行环境,因此可以在浏览器环境中调试Weex项目代码。在Weex工程中运行npm run dev和npm run serve命令并在浏览器中访问http://localhost:8080即可预览Weex项目效果,如下图所示。但是就目前的状况来讲,Weex对三端的兼容性支持还不是很完善,在浏览器中调试好的代码再放到客户端环境中运行还是有极大的可能会出问题,因此如果最终目标只是想在客户端中运行Weex代码,并不建议通过浏览器来调试。

image

Weex Playground APP集成了Weex SDK,可以通过它的扫码功能来调试自己的Weex项目代码。项目开始时,如果客户端Weex集成工作还没完成且调试环境还没有准备好,可以使用Weex Playground APP来辅助调试,因为此时项目的主要工作还是编写界面,并不需要客户端扩展功能模块的支持。

项目界面开发完成后,后面阶段的调试工作就需要在自己的应用内进行了,因为此时一般需要客户端扩展的功能模块或组件的支持。例如,获取网络请求通用参数、打点、接收客户端事件消息等。应用内集成了Weex SDK后,在需要调试Weex代码的页面,建议客户端在DEBUG模式下提供刷新页面按钮以方便调试。

1.2.2 DEBUG

在React Native的开发中,可以通过点击开发者菜单中的“Debug JS Remotely”选项来开启JS代码的远程调试。然而在Weex的开发中,开启JS代码远程调试功能的步骤要麻烦一些,需要在应用内集成Weex DevTools工具。由于Weex Playground APP已经集成了Weex DevTools工具,可以使用Weex Playground APP来试验一下如何使用weex-toolkit里面提供的调试工具。

首先,在命令行中运行weex debug命令,该命令会启动一个调试服务器,并同时唤起Chrome浏览器打开调试主页,如下图所示。

image

然后,打开Weex Playground APP扫描调试主页下方的二维码,即可在应用与调试服务器之间建立socket连接并向调试服务器注册应用信息,如下图所示。

image

此时,点击上图中的Debugger按钮可以开启JavaScript代码的远程调试功能,在ChromeDevTools里面对Weex工程的JavaScript代码进行调试;点击Inspector按钮可以查看Weex页面的element属性结构。

如果想使用weex-toolkit提供的调试工具对自己应用内的Weex页面进行调试,必须先在应用内集成Weex DevTools。具体集成方法请参考:集成 DevTools 到 iOS和集成 DevTools 到 Android。

1.3 开发

此次Weex应用于内涵的发现页,发现页的UI如下面三张图所示。发现页有以下特征:

  • 由热吧和订阅两个列表页组成,通过顶TAB进行切换;

  • 热吧和订阅数据一次性加载完毕,无loadmore逻辑,热吧数据大概在200~300条;

  • 用户可切换主题:白天模式和夜间模式。

image
image
image

1.3.1 组件划分及布局

发现页的页面组成元素比较简单,组件分为轮播图组件、热吧Cell组件以及订阅吧Cell组件。

发现页的文档结构大致如下:

image

其中值得一提的是实现TAB切换的方式。一般来讲,很容易想到使用vue的条件渲染来实现TAB的切换,如下:

image

但是这样做会造成TAB切换时列表渲染卡顿,因为热吧列表有200~300条数据,每次切换都重新渲染一次会造成较大的性能消耗。因此,在实现的时候对list采用了绝对定位的布局方式,在TAB切换的时候,将已经渲染好的列表结构在DOM树中保留,只改变列表节点的visibility属性。如下:

image

1.3.2 客户端支持

(1) 客户端模块

device模块

Method Description Parameters Callback
getCommonNetworkParameters 获取网络请求通用参数 commonNetworkParams: Object

event模块

Method Description Parameters Callback
openURL 页面跳转 url:String

tracker模块

Method Description Parameters Callback
logEvent 打点 event:String,parameters:Object

(2) 客户端事件

Event Type Parameters
主题切换 theme theme:0-白天模式,1-夜间模式
消息红点事件 badge subscribedBadge:false-不显示红点,true-显示红点
订阅/取消订阅 subscribe type:false-取消订阅,true-订阅id:相关id
登录状态切换 loginstatus loginstatus: true-登录,false -退出登录

1.3.3 Weex使用问题总结

如何处理本地图片资源?
Weex image组件不支持本地图片,然而在项目开发过程中经常需要引入一些本地图标文件,例如:

image

此时,可以在webpack配置文件里面配置url-loader,将图片资源输出到构建目录。然后,通过output.publicPath配置项来配置资源的访问路径,在DEBUG模式下,将output.publicPath配置为本机server地址,在Production模式下,将output.publicPath配置为线上域名。由于图标文件一般比较小,为了避免在无网络状态下渲染Weex页面拉取不到线上图标资源的情况,项目中将图标文件直接用Base64编码。url-loader的配置如下所示:

image
  • 关于适配
    Weex代码中的高度和宽度的单位均为px,但是所设置的宽高并不是实际呈现出来的宽高,Weex框架在底层做了针对不同屏幕的适配工作,具体计算公式为 实际高宽 = 代码高宽 * (屏幕宽度 / 750)。所以,在编写界面的时候,最好以宽度为750的设计稿最为标准,否则需要根据计算公式对设计稿上标明的宽高做转换。当需要设置元素的绝对宽高时,需要自行计算。计算时,需要获取以下参数:
image
  • cell组件的appear事件和disappear事件在安卓端引发的性能问题
    在热吧列表,有一个打点需求,就是统计每一个吧Cell的展示时间。为了实现这个打点需求,对每一个吧Cell都监听了appear事件和disappear事件。通过测试发现,当监听了吧Cell的appear事件和disappear事件时,安卓端列表滚动不流畅,会出现明显的卡顿现象。

  • slider组件的点击事件在安卓端不触发
    由于Weex提供的slider组件无法满足使用要求,所以基于slider重新封装了一个轮播图组件,结构如下:

image
  • 轮播图组件需要监听点击事件,当在slider组件或slider组件的父组件div上监听点击事件时,在安卓端点击轮播图并不触发点击事件。因此,需要在slider组件的子组件上监听点击事件。 在没有设置loadmoreoffset时,list组件的loadmore事件在安卓端不触发 虽然发现页没有loadmore逻辑,但是在使用weex的过程中对list组件进行了性能测试,使用到了list组件的loadmore功能,因此发现了list组件的loadmore事件在默认情况下不触发的问题。只有显示设置了loadmoreoffset且loadmoreoffset的值大于0时,list组件的loadmore事件才会触发。

  • cell组件的scope属性
    使list组件的时候,建议为同种类的cell设置相同的scope属性。Weex内部会缓冲cell,每种类型的cell最多缓冲9个。如果不设置cell的scope属性,weex会认为所有的cell的类型都不一样,会缓冲所有的cell,导致内存占用大。

1.3.4 Weex实现效果

Weex实现的页面操作体验基本上接近原声应用,列表滚动、TAB切换、页面跳转等都十分流畅。效果如下图所示:

image

二、实践总结

Weex可以选择使用Vue作为开发框架,开发与调试体验都比较好,接近Web开发体验,但是使用上仍然存在一些问题,例如:

  • CSS支持不够完善,有些地方CSS样式的在客户端中的表现与WEB中的不太一致,甚至iOS和安卓端都会存在样式表现的不一致。而且CSS不支持继承,定义CSS样式的时候无法引入变量,这样在实现一些效果的时候十分不方便,例如白天模式和夜间模式;

  • 文档资料不够完善;

  • 某些内建组件存在使用上的BUG,例如slider组件在安卓手机上无法监听click事件、list组件在没有设置loadmoreoffset的情况下在安卓手机上不触发loadmore事件;

当然,这些使用上的问题都可以解决或通过一定办法去规避。Weex更值得我们关注的问题可能还是list组件的性能问题。在React Native的实践中,我们深受长列表性能问题的困扰,而Weex号称是一套可以构建高性能原声应用的跨平台方案,它在长列表的性能表现上如何呢?我们对此进行了测试和评估,发现Weex在长列表的性能表现上也并不乐观。在列表长度不断增长的时候,Weex的内存占用也是不断增长的,在安卓和iOS上皆是如此。在iOS上,列表在不断向下滚动的过程中,CPU使用率的表现也十分堪忧。以下两张图分别是在列表cell定高和变高下的测试结果【详细测试结果请前往:RN & Weex ListView性能对比评估】:

image
image

因此,Weex目前可能更适用于非长列表的场景。由于其体验接近原生应用,比H5要好,可以用于替换端内的一些H5页面或一些需要频繁变动的客户端页面。在这些方面Weex是否可规模投入使用尚待验证,此次在内涵发现页的使用正好可以观察其稳定性。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • 补充 豆知識(まめちしき):豆知识是日语中的一个说法,指一些日常生活中鲜为人知但又实用的小窍门。毎日ひとつ、豆知識...
    QihuaZhou阅读 552评论 0 2
  • 第三章 混战“砰砰……!”两声金铁交鸣的巨响声突兀的传来,一左一右控制着美女老妈的两个女子快反的队员只是听见声音...
    拂晓雪阅读 317评论 0 1
  • 复杂的事情简单化 见了朋友吃了饭 下次见面也不知道什么时候了 祝福
    初五啊阅读 202评论 0 0
  • 几欲寻高楼一跃而下,谁道少年强? 行路欲倒少年小, 咿呀学语事渐晓。 本应野花笑总角, 可惜功名早到了。 ​​​
    樊小篱阅读 315评论 2 9