美文网首页
Uni-app之Nvue开发细节总结

Uni-app之Nvue开发细节总结

作者: 大码猴 | 来源:发表于2021-11-03 14:50 被阅读0次

    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. 文字内容,必须、只能在<text>组件下,只有<text>标签可以设置字体大小,字体颜色。
    4. 不支持背景图background-image。但可以使用<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轴偏移量 阴影模糊半径  阴影颜色}
    
    <view elevation="5px"></view>
    

    其他:待补充

    相关文章

      网友评论

          本文标题:Uni-app之Nvue开发细节总结

          本文链接:https://www.haomeiwen.com/subject/ygmqzltx.html