微信小程序新版渲染引擎Skyline的使用详解

您所在的位置:网站首页 闪婚厚爱舒馨厉谨琛 微信小程序新版渲染引擎Skyline的使用详解

微信小程序新版渲染引擎Skyline的使用详解

2024-07-06 10:54| 来源: 网络整理| 查看: 265

今年年初,在官方文档上看到小程序团队要推出一款性能逼近原生的渲染引擎Skyline,就一直在关注。刚好最近打算做一款新的阅读小程序,作为一名独立开发者,对于性能和用户体验的追求是永无止境的,于是我决定用纯Skyline打造这款小程序。

当然,这个项目里面所用到的skyline特性只是冰山一角,并非全部,更多酷炫的特性请前往官方文档查阅。

接下来,我会结合快书小程序,从以下几个方面,逐条阐述关于skyline特性(快书项目中所用到的)的理解与应用:

1. 效果演示。 2. 如何开启Skyline。 3. 新版组件swiper。 4. 新版组件scroll-view。 5. 全新组件snapshot。 6. 增强特性worklet动画。 7. 增强特性手势系统。 8. 增强特性自定义路由。 9. 增强特性共享元素动画。

希望对于刚接触Skyline,或者想要了解Skyline的同学有所帮助。当然,如有错误或遗漏,欢迎在评论区批评指正,不胜感激。

一、效果演示

image

二、如何开启Skyline

开启Skyline的方式非常简单,只需要在app.json文件中,加入以下配置即可(这里是全局Skyline,若只打算指定页面开启,则在指定页面的json文件中配置即可):

"renderer":"skyline", "lazyCodeLoading":"requiredComponents", "rendererOptions": { "skyline": { "defaultDisplayBlock":true, } }, "componentFramework":"glass-easel", 三、新版组件-Swiper

旧版的Swiper基于webview的,在性能上有所局限,特别是当swiper-item的数量动态不断增加的情况下。当然,也可以自己想办法去优化,比如做懒加载和缓存,但相对来说比较麻烦。而Skyline版本的Swiper性能会大幅度提升,首先渲染引擎本身的性能提升了,另外官方也做了缓存的功能,只需要通过定义cache-extent的值,就能轻松定义缓存区域大小,例如值为 1 则表示提前渲染上下各一屏区域。

swiper

用法上,和webview版本没有太大区别(这里就不放代码了),只需注意不要使用某些webview独有的特性即可。

四、新版组件-Scroll-view

同样,旧版的scroll-view也基于webview的,滚动元素过多的时候会有明显卡顿,当然也是可以通过虚拟Dom的方式自行优化。然而,Skyline版本的scroll-view官方已经实现了只会渲染在屏节点的特性,大大提升了滚动的流畅度,真正做到了开箱即用。

用法上,有以下几个点要注意的。

指定type属性,有2个可选值,分别为:list和custom,对应的是列表模式和自定义模式。如是普通列表,list即可,如果是稍微复杂的列表,比如常见的瀑布流表现形式(类似小红书那样),则可使用custom。

只有直接子节点才能根据是否在屏来按需渲染。即你不能把你的列表项,都放在同一个父级view中,而是应该直接放在scroll-view组件下。

// 错误的方式:


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3