情诗网 >内涵情话 > 正文

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

来源:情诗网    2020-12-14    分类:内涵情话

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如下面三张图所示。发现页有以下特征:

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
image
image

1.3.4 Weex实现效果

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

image

二、实践总结

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

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

image
image

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

热门文章