uniapp之nvue
一. nvue的使用场景
- 如果你不开发App,那么不需要使用nvue
比如:nvue只能使用css选择器,而且有些写法受限 - 为了实现app页面的性能优化,因为在App端,如果使用vue页面,则使用webview渲染;如果使用nvue页面(native vue的缩写),则使用原生渲染,原生更快
- 层级问题
解决前端控件无法覆盖原生控件的层级问题。(在vue页面中)当你使用map、video、live-pusher等原生组件时,会发现前端写的view等组件无法覆盖原生组件,层级问题处理比较麻烦,此时使用nvue更好。因为nvue页面全部都是原生组件,互相之间没有层级问题。
(或者在vue页面上也可以覆盖一个subnvue(一种非全屏的nvue页面覆盖在webview上),以解决App上的原生控件层级问题;
或者使用cover-view,但只能覆盖原生组件,不能覆盖其他原生界面元素。比如cover-view可以覆盖video、map,但无法覆盖原生导航栏、tabbar、web-view。) - 原生组件问题
map,video,live-pusher组件等,很多时候,官方都会推荐使用nvue,所以要注意一下。 - 其他
https://uniapp.dcloud.io/nvue-outline
二. nvue页面的写法
1. 新建页面
新建nvue页面,如果一个页面路由下同时有vue页面和nvue页面,即出现同名的vue和nvue文件。那么在App端,会仅使用nvue页面,同名的vue文件将不会被编译到App端。而在非App端,会优先使用vue页面。
2. 开发页面
2.1 template
(1)可以使用到nvue专用组件,比如barcode和waterfall等
(2)只能使用v-if
(3)文本只能在text中,不能换行写内容,否则会出现无法去除的周边空白
(4)只能使用vue的数组语法,对象语法可以嵌套在里面,但class绑定的一定是数组
(5)图片使用image标签,支持使用base64,不支持svg格式图片
2.2 script
(1) 支持nvue的api,使用前导入模块,有uniapp内置插件也有第三方
(2) H5+,轻松调用手机的功能,nvue页面可直接使用plus的API,并且不需要等待plus ready。,http://www.html5plus.org/doc/h5p.html
(3) 支持uniapp的api,uni.navigateTo等
2.3 style
(1) 只能用flex布局,而且flex-direction是默认方向是column,可以全局设置https://uniapp.dcloud.io/collocation/manifest?id=nvue
(2) 只能用class选择器
(3) nvue组件默认是透明的,一定要用background-color,不然可能有重影
(4) 没有百分比,没有媒体查询
(5) 不能在 style 中引入字体文件,可以使用 DOM.addRule 以加载自定义字体
(6) 不支持在 nvue 页面使用 typescript/ts
(7) 尽量用原生导航
(8) 不支持在css里写背景图background-image
三. 总结
除了一些特殊考虑,涉及到app的东西,最好就是看下vue支不支持,不得已再用nvue。
以上总结于2022/2/27制定,由于uniapp会更新和优化,所以以上的总结可能会改变,所以这里只是整理了目前的存在的坑,详情还是以uniapp社区为主
原文地址:https://www.cnblogs.com/listenMao/p/15949870.html
- 如何让ASP.NET默认的资源编程方式支持非.ResX资源存储
- 在VS中通过建立依赖关系使文件结构更清晰
- 一个关于ConfigurationManager.GetSecion方法的小问题
- 追踪记录每笔业务操作数据改变的利器——SQLCDC
- 一个完整的用于追踪数据改变的解决方案
- C# 4.0新特性-"协变"与"逆变"以及背后的编程思想
- 通过内存分析工具来证明字符串驻留机制
- 如果在BackgroundWorker运行过程中关闭窗体…
- 从数据到代码——基于T4的代码生成方式
- 解决T4模板的程序集引用的五种方案
- 编写T4模板进行代码生成无法避免的两个话题:"Assembly Locking"&"Debug"
- 从yield关键字看IEnumerable和Collection的区别
- 让“链式调用(方法链)”更加自然一点
- ASP.NET应用下基于SessionState的“状态编程框架”解决方案
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法