Uni-app之Nvue开发细节总结
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>
作者:大码猴
链接:https://www.jianshu.com/p/2fc394637e23
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
Uni-app之Nvue开发细节总结相关推荐
- uni-app简介、条件编译、App端Nvue开发、HTML5+、开发环境搭建、自定义组件、配置平台环境、uniCloud云开发平台
uni-app简介 : 概述:uni-app是一个前端跨平台框架:会uni-app就可以用一套代码(类似vue语法)打包出安卓.ios.及各种小程序(微信.qq.支付宝等)端跨平台发布. 生态:完整的 ...
- uni app和php开发微信登录代码,uniapp如何实现微信授权登录
uniapp实现微信授权登录的方法:首先获取对应的appid和appsecret:然后在uniapp项目的manifest.json中进行APP SDK配置和模块权限配置.最后实现编码. 本教程操作环 ...
- 直播APP源码开发细节、成本、一对一比心陪玩源码实操
2018年归属于YY的净利润为31.964亿元.陌陌的净利润为34.621亿元. 2014年年底上市的陌陌已经持续16个季度盈利,其营收主要来自于直播.增值业务.移动营销和移动游戏,直播业务依然是陌陌 ...
- 切换 uniapp_万能前端框架uni app初探03:底部导航开发
前言 本节我们使用uni app的底部导航功能,点击不同tab会显示不同页面,这个功能在实际项目开发中几乎是必备的. 一.基础知识 1.tabBar 如果应用是一个多 tab 应用,可以通过 tabB ...
- uni app 开发微信小程序及上线体验
uni app 开发微信小程序及上线体验 项目创建及微信小程序AppId的申请 本次开发的是电商类的微信小程序,这里用到的是HBuilderX这个编辑器.之前用的Visual Studio Code ...
- 没个百来万就想自建技术团队?亲身经历告诉你,一个APP从无到有的开发到底要花多少钱!...
作为一名苦逼的移动互联网创业者,被外行的朋友们问及最多的问题是"做一个网站需要多少钱?"或者"做一个APP需要多少钱?" 3年前,天真的我认为做一个APP顶多5 ...
- uni.app H5(微信公众号定位) uni.getLocation
最近在开发公众号,由于之前经常使用uni,app写APP,索性就用uni.app来开发公众号了, 不过也遇到了一个问题,就是在公众号的首页要获取用户的定位.我看了看官网的API 有个uni.getLo ...
- 详细直播平台开发细节,提供成品直播系统源码
直播的火爆从2016年一直烧到了2018年,直播平台开发的技术--直播APP源码也渐渐浮出水面,在直播大火的现在,您是不是也想要一款独属于自己的直播平台呢?小编今天为您讲解一款简易直播平台开发细节. ...
- HbuilderX:uni app踩坑之uView-ui
HbuilderX:uni app踩坑之uView-ui 最近在自学uniapp,想找一个ui框架提高一下学习和开发的效率,于是就网上冲浪,浪来浪去,最后选择了uView-ui这款.其实有些框架我是有 ...
最新文章
- no copy constructor available or copy constructor is declared #39;explicit#39;
- Microsoft Visual Studio (VS)2010 常用快捷键大全 便捷开发
- android反编译的方法
- Docker(基础理解)
- 放个手机在单位自动打卡_1秒识别打卡,无感知考勤系统重磅来袭!
- 手机访问同局域网下的PC中Tomcat中的项目
- php7.3安装yaf扩展
- SAP UI5 Web Component React应用如何在Component之间跳转
- sharedPreferences的用法
- java 9 mc_Java基础9
- 基于SSM的猫头鹰在线视频网站
- DXBC2HLSL Tool
- [Pytorch系列-26]:神经网络基础 - 多个带激活函数的神经元实现非线性回归
- pdo_mysql扩展库_MySQL数据库之PDO扩展
- 音频、音频属性-采样精度、比特率、音频格式
- henauOJ055(猴子吃桃)
- 完数:求1000以内所有完数
- B站数据分析岗实习生面试记录
- 一个apk通过隐式Intent 启动另一个apk
- 计算机房配备空调,信息机房空调配置的计算
热门文章
- R语言caret机器学习(二):数据预处理上
- 校园招聘--网易笔试
- 比KEEP更好,运动健身、塑形瘦身的小程序新选择
- EndeavourOS移动硬盘安装
- 二进制、八进制、十进制、十六进制的前缀和后缀
- 超便捷好用的-圆形花瓣加载滚动图片插件spin.js
- 2017.2.10考试总结2017冬令营
- 关于Google Map 叠加层之Polyline(折线)、Polygon(多边形)、InfoWindow(信息窗口)
- 8086/88系统中CLK引脚需要的8284时钟发生器
- android 加载网络图片,并压缩bitmap内存大小