Uni-app之Nvue开发细节总结

uni-app App端内置了一个基于 weex 改进的原生渲染引擎,提供了原生渲染能力

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

其他:待补充

你可能感兴趣的:(Uni-app之Nvue开发细节总结)