uni-app App端内置了一个基于 weex 改进的原生渲染引擎,提供了原生渲染能力
适用场景
- 需要高性能的区域长列表或瀑布流滚动。webview的页面级长列表滚动是没有性能问题的,但页面中某个区域做长列表滚动,则需要使用nvue的
list
、recycle-list
、waterfall
等组件(详见)。这些组件的性能要高于vue页面里的区域滚动组件scroll-view
。 - 左右拖动的长列表。在webview里,通过
swiper
+scroll-view
实现左右拖动的长列表,前端模拟下拉刷新,这套方案的性能不好。此时推荐使用nvue,比如新建uni-app项目时的新闻示例模板,就采用了nvue,切换很流畅 - 如深度使用map组件,建议使用nvue。除了层级问题,App端nvue文件的map功能更完善,和小程序拉齐度更高,多端一致性更好。
- 如深度使用
video
,建议使用nvue。比如如下2个场景:video内嵌到swiper中,以实现抖音式视频滑动切换,例子见插件市场;nvue的视频全屏后,通过cover-view
实现内容覆盖,比如增加文字标题、分享按钮。 - 对App启动速度要求极致化。App端如果首页使用nvue且在manifest里配置fast模式,那么App的启动速度可以控制在1秒左右。而使用vue页面的话,App的启动速度一般是3秒起,取决于你的代码性能和体积。
Nvue与vue区别
- nvue 页面控制显隐只可以使用
v-if
不可以使用v-show
。 - nvue 页面只能使用
flex
布局,不支持其他布局方式。 - 文字内容,必须、只能在
<text>
组件下,只有<text>
标签可以设置字体大小,字体颜色。 - 不支持背景图
background-image
。但可以使用<image>
组件和层级来实现类似web中的背景效果。 - css选择器支持的比较少,只能使用 class 选择器,class 进行绑定时只支持数组语法
- 在 App.vue 中定义的全局js变量不会在 nvue 页面生效。
globalData
和vuex
是生效的. - 不能在 style 中引入字体文件。可使用以下写法
beforeCreate() {
const domModule = uni.requireNativePlugin('dom')
domModule.addRule('fontFace', {
'fontFamily': "myIconfont",
'src': "url('http://at.alicdn.com/t/font_2234252_v3hj1klw6k9.ttf')"
});
}
- 不能使用百分比布局,如
width:100%
- Nvue与Vue直接可以通过
uni.$on
,uni.$emit
进行通讯,注意要在界面销毁前调用uni.$off
销毁监听器,或者使用uni.$once
. - Nvue与Vue共享数据vuex、uni.storage、globalData。推荐使用vuex(之后会出一篇简书总结vuex使用示例)。
兼容性
- style:由于采用原生渲染,并非所有浏览器的 css 均支持,布局模型只支持 flex 布局
- 设置render-whole="true"时,视图层将组件以及子组件的信息结构一次性和原生层通讯,通过整个节点的重绘提升了排版渲染性能。
设置render-whole="false"时,视图层将以子节点一个接着一个和原生层通讯再重绘。总体的渲染时间可能更久。 - 目前暂不支持
radial-gradient
(径向渐变)
安卓与iOS区别
- nvue 的各组件在安卓端默认是透明的,如果不设置background-color,可能会导致出现重影的问题。
- iOS下
refresh
可使用alwaysScrollableVertical
支持上下滚动,支持下拉操作。 - 如果定位元素超过容器边界,在 Android 下,超出部分将不可见,原因在于 Android 端元素
overflow
默认值为hidden
,但目前 Android 暂不支持设置overflow: visible
- iOS平台阴影
box-shadow
,安卓平台阴影elevation
(组件的属性,不是css样式)
{box-shadow:inset offset-x offset-y blur-radius color}
{box-shadow:投影方式 X轴偏移量 Y轴偏移量 阴影模糊半径 阴影颜色}
<view elevation="5px"></view>
其他:待补充