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>

作者:大码猴
链接:https://www.jianshu.com/p/2fc394637e23
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

Uni-app之Nvue开发细节总结相关推荐

  1. uni-app简介、条件编译、App端Nvue开发、HTML5+、开发环境搭建、自定义组件、配置平台环境、uniCloud云开发平台

    uni-app简介 : 概述:uni-app是一个前端跨平台框架:会uni-app就可以用一套代码(类似vue语法)打包出安卓.ios.及各种小程序(微信.qq.支付宝等)端跨平台发布. 生态:完整的 ...

  2. uni app和php开发微信登录代码,uniapp如何实现微信授权登录

    uniapp实现微信授权登录的方法:首先获取对应的appid和appsecret:然后在uniapp项目的manifest.json中进行APP SDK配置和模块权限配置.最后实现编码. 本教程操作环 ...

  3. 直播APP源码开发细节、成本、一对一比心陪玩源码实操

    2018年归属于YY的净利润为31.964亿元.陌陌的净利润为34.621亿元. 2014年年底上市的陌陌已经持续16个季度盈利,其营收主要来自于直播.增值业务.移动营销和移动游戏,直播业务依然是陌陌 ...

  4. 切换 uniapp_万能前端框架uni app初探03:底部导航开发

    前言 本节我们使用uni app的底部导航功能,点击不同tab会显示不同页面,这个功能在实际项目开发中几乎是必备的. 一.基础知识 1.tabBar 如果应用是一个多 tab 应用,可以通过 tabB ...

  5. uni app 开发微信小程序及上线体验

    uni app 开发微信小程序及上线体验 项目创建及微信小程序AppId的申请 本次开发的是电商类的微信小程序,这里用到的是HBuilderX这个编辑器.之前用的Visual Studio Code ...

  6. 没个百来万就想自建技术团队?亲身经历告诉你,一个APP从无到有的开发到底要花多少钱!...

    作为一名苦逼的移动互联网创业者,被外行的朋友们问及最多的问题是"做一个网站需要多少钱?"或者"做一个APP需要多少钱?" 3年前,天真的我认为做一个APP顶多5 ...

  7. uni.app H5(微信公众号定位) uni.getLocation

    最近在开发公众号,由于之前经常使用uni,app写APP,索性就用uni.app来开发公众号了, 不过也遇到了一个问题,就是在公众号的首页要获取用户的定位.我看了看官网的API 有个uni.getLo ...

  8. 详细直播平台开发细节,提供成品直播系统源码

    直播的火爆从2016年一直烧到了2018年,直播平台开发的技术--直播APP源码也渐渐浮出水面,在直播大火的现在,您是不是也想要一款独属于自己的直播平台呢?小编今天为您讲解一款简易直播平台开发细节. ...

  9. HbuilderX:uni app踩坑之uView-ui

    HbuilderX:uni app踩坑之uView-ui 最近在自学uniapp,想找一个ui框架提高一下学习和开发的效率,于是就网上冲浪,浪来浪去,最后选择了uView-ui这款.其实有些框架我是有 ...

最新文章

  1. no copy constructor available or copy constructor is declared #39;explicit#39;
  2. Microsoft Visual Studio (VS)2010 常用快捷键大全 便捷开发
  3. android反编译的方法
  4. Docker(基础理解)
  5. 放个手机在单位自动打卡_1秒识别打卡,无感知考勤系统重磅来袭!
  6. 手机访问同局域网下的PC中Tomcat中的项目
  7. php7.3安装yaf扩展
  8. SAP UI5 Web Component React应用如何在Component之间跳转
  9. sharedPreferences的用法
  10. java 9 mc_Java基础9
  11. 基于SSM的猫头鹰在线视频网站
  12. DXBC2HLSL Tool
  13. [Pytorch系列-26]:神经网络基础 - 多个带激活函数的神经元实现非线性回归
  14. pdo_mysql扩展库_MySQL数据库之PDO扩展
  15. 音频、音频属性-采样精度、比特率、音频格式
  16. henauOJ055(猴子吃桃)
  17. 完数:求1000以内所有完数
  18. B站数据分析岗实习生面试记录
  19. 一个apk通过隐式Intent 启动另一个apk
  20. 计算机房配备空调,信息机房空调配置的计算

热门文章

  1. R语言caret机器学习(二):数据预处理上
  2. 校园招聘--网易笔试
  3. 比KEEP更好,运动健身、塑形瘦身的小程序新选择
  4. EndeavourOS移动硬盘安装
  5. 二进制、八进制、十进制、十六进制的前缀和后缀
  6. 超便捷好用的-圆形花瓣加载滚动图片插件spin.js
  7. 2017.2.10考试总结2017冬令营
  8. 关于Google Map 叠加层之Polyline(折线)、Polygon(多边形)、InfoWindow(信息窗口)
  9. 8086/88系统中CLK引脚需要的8284时钟发生器
  10. android 加载网络图片,并压缩bitmap内存大小