uni-app多平台融合【入门】(标贝科技)
标贝科技 https://ai.data-baker.com/#/?source=qwer12
填写邀请码fwwqgs,每日免费调用量还可以翻倍
uni-app多平台融合【入门】(标贝科技)
一、uni-app介绍
uni-app 是一个使用 Vue.js 开发所有前端应用的框架,开发者编写一套代码,可发布到iOS、Android、Web(响应式)、以及各种小程序(微信/支付宝/百度/头条/飞书/QQ/快手/钉钉/淘宝)、快应用等多个平台。
二、功能框架
从下面uni-app功能框架图可看出,uni-app在跨平台的过程中,不牺牲平台特色,可优雅的调用平台专有能力,真正做到海纳百川、各取所长。
三、使用工具【推荐】
HBuilderX 【官网下载地址:https://www.dcloud.io/hbuilderx.html】
四、uni-app 优缺点
1.使用多端开源框架
2. uni-app拓展能力强【有丰富的插件市场】https://ext.dcloud.net.cn/
2.通用前端技术栈,学习成本更低
3.支持通过npm安装第三方包
五、创建项目
1.通过 HBuilderX 可视化界面创建项目
(1)创建uni-app 【点击工具栏的文件 -> 新建 -> 项目】
(2)创建模板,选择uni-app 创建演示模板
①
(3)运行uni-app到【浏览器】
(4)运行uni-app到【小程序】
(5)运行到其他程序同理,需下载对应的开发者工具
(6)通过manifest.json 进行发行配置
①
②
③
④
2.通过命令行进行创建项目
…
六、目录结构
┌─uniCloud 云空间目录,阿里云为uniCloud-aliyun,腾讯云为uniCloud-tcb(详见uniCloud)
│─components 符合vue组件规范的uni-app组件目录
│ └─comp-a.vue 可复用的a组件
├─hybrid App端存放本地html文件的目录,详见
├─platforms 存放各平台专用页面的目录,详见
├─pages 业务页面文件存放的目录
│ ├─index
│ │ └─index.vue index页面
│ └─list
│ └─list.vue list页面
├─static 存放应用引用的本地静态资源(如图片、视频等)的目录,注意:静态资源只能存放于此
├─uni_modules 存放[uni_module](/uni_modules)规范的插件。
├─wxcomponents 存放小程序组件的目录,详见
├─unpackage 打包文件
├─main.js Vue初始化入口文件
├─App.vue 应用配置,用来配置App全局样式以及监听 应用生命周期
├─manifest.json 配置应用名称、appid、logo、版本等打包信息,详见
├─pages.json 配置页面路由、导航条、选项卡等页面类信息,详见
└─uni.scss 这里是uni-app内置的常用样式变量
七、跨端兼容
uni-app 已将常用的组件、JS API 封装到框架中,开发者按照 uni-app 规范开发即可保证多平台兼容,大部分业务均可直接满足。
但每个平台有自己的一些特性,因此会存在一些无法跨平台的情况。
- 大量写 if else,会造成代码执行性能低下和管理混乱。
- 编译到不同的工程后二次修改,会让后续升级变的很麻烦。
在 C 语言中,通过 #ifdef、#ifndef 的方式,为 windows、mac 等不同 os 编译不同的代码。 uni-app 参考这个思路,为 uni-app 提供了条件编译手段,在一个工程里优雅的完成了平台个性化实现。
八、条件编译
条件编译是用特殊的注释作为标记,在编译时根据这些特殊的注释,将注释里面的代码编译到不同平台。
写法:以 #ifdef 或 #ifndef 加 %PLATFORM% 开头,以 #endif 结尾。
#ifdef:if defined 仅在某平台存在
#ifndef:if not defined 除了某平台均存在
%PLATFORM%:平台名称
条件编译写法 说明
条件编译写法 | 说明 |
---|---|
#ifdef APP-PLUS 需条件编译的代码 #endif |
仅出现在 App 平台下的代码 |
#ifndef H5 需条件编译的代码 #endif |
除了 H5 平台,其它平台均存在的代码 |
#ifdef H5 || MP-WEIXIN 需条件编译的代码 #endif |
在 H5 平台或微信小程序平台存在的代码(这里只有||,不可能出现&&,因为没有交集) |
%PLATFORM% 可取值如下:
值 | 生效条件 |
---|---|
VUE3 | HBuilderX 3.2.0+ |
APP-PLUS | App |
APP-PLUS-NVUE或APP-NVUE | App nvue |
H5 | H5 |
MP-WEIXIN | 微信小程序 |
MP-ALIPAY | 支付宝小程序 |
MP-BAIDU | 字节跳动小程序 |
MP-LARK | 飞书小程序 |
MP-QQ | QQ小程序 |
MP-KUAISHOU | 快手小程序 |
MP-360 | 360小程序 |
MP | 微信小程序/支付宝小程序/百度小程序/字节跳动小程序/飞书小程序/QQ小程序/360小程序 |
QUICKAPP-WEBVIEW | 快应用通用(包含联盟、华为) |
QUICKAPP-WEBVIEW-UNION | 快应用联盟 |
QUICKAPP-WEBVIEW-HUAWEI | 快应用华为 |
支持的文件
- .vue
- .js
- .css
- pages.json
- 各预编译语言文件,如:.scss、.less、.stylus、.ts、.pug
注意:
条件编译是利用注释实现的,在不同语法里注释写法不一样,js使用 // 注释、css 使用 /* 注释 */、vue/nvue 模板里使用<!-- 注释 -->;
- 条件编译APP-PLUS包含APP-NVUE和APP-VUE,APP-PLUS-NVUE和APP-NVUE没什么区别,为了简写后面出了APP-NVUE
; - 使用条件编译请保证编译前和编译后文件的正确性,比如json文件中不能有多余的逗号;
- VUE3 需要在项目的 manifest.json 文件根节点配置 “vueVersion” : “3”
API 的条件编译
// #ifdef %PLATFORM%
平台特有的API实现// #endif
示例,如下代码仅在 App 下出现:
示例,如下代码不会在 H5 平台上出现:
除了支持单个平台的条件编译外,还支持多平台同时编译,使用 || 来分隔平台名称。
示例,如下代码会在 App 和 H5 平台上出现:
组件的条件编译
<!-- #ifdef %PLATFORM% -->
平台特有的组件<!-- #endif -->
示例,如下公众号关注组件仅会在微信小程序中出现:
<view><view>微信公众号关注组件</view><view><!-- uni-app未封装,但可直接使用微信原生的official-account组件--><!-- #ifdef MP-WEIXIN --><official-account></official-account><!-- #endif --></view></view>
样式的条件编译
/* #ifdef %PLATFORM% */
平台特有样式/* #endif */
注意: 样式的条件编译,无论是 css 还是 sass/scss/less/stylus 等预编译语言中,必须使用/*注释*/ 的写法。
正确写法
错误写法
pages.json 的条件编译
下面的页面,只有运行至 App 时才会编译进去。
不同平台下的特有功能,以及小程序平台的分包,都可以通过 pages.json 的条件编译来更好地实现。这样,就不会在其它平台产生多余的资源,进而减小包体积。
json的条件编译,如不同平台的key名称相同,cli项目下开发者自己安装的校验器会报错,需自行关闭这些校验器对json相同key的校验规则。如果使用HBuilderX的校验器,无需在意此问题,HBuilderX的语法校验器为此优化过。
static 目录的条件编译
在不同平台,引用的静态资源可能也存在差异,通过 static 的的条件编译可以解决此问题,static 目录下新建不同平台的专有目录(目录名称同 %PLATFORM% 值域,但字母均为小写),专有目录下的静态资源只有在特定平台才会编译进去。
如以下目录结构,a.png 只有在微信小程序平台才会编译进去,b.png 在所有平台都会被编译。
┌─static
│ ├─mp-weixin
│ │ └─a.png
│ └─b.png
├─main.js
├─App.vue
├─manifest.json
└─pages.json
整体目录条件编译
如果想把各平台的页面文件更彻底的分开,也可以在uni-app项目根目录创建platforms目录,然后在下面进一步创建app-plus、mp-weixin等子目录,存放不同平台的文件。
uni-app多平台融合【入门】(标贝科技)相关推荐
- kaldi新手入门及语音识别的流程(标贝科技)
kaldi新手入门及语音识别的流程(标贝科技) 欢迎体验标贝语音开放平台 地址:https://ai.data-baker.com/#/?source=qaz123 (注:填写邀请码hi25d7,每日 ...
- 标贝科技推出「留声机」TTS方案,高还原、个性化声效提升交互意愿
3 月 5 日,标贝科技推出全新 「留声机」,该方案具有高原度复刻效果,用户只需 5 分钟左右即可完成录制,训练过程全自动化处理,大约 2 小时后,即可拥有媲美原声声音的个性化模型,轻松实现文本转语音 ...
- 标贝科技登全球语音大赛舞台Blizzard Challenge做精彩开场发言
继语音论文成功入选并亮相全球顶级语音学术会议INTERSPEECH2019后,标贝科技再登全球语音大赛舞台Blizzard Challenge2019(译为暴雪挑战赛). 9月23日,全球语音合成领域 ...
- 标贝科技声音克隆技术赋能 定制语音功能让陪伴触手可及
"常回家看看,回家看看,哪怕帮妈妈刷刷筷子洗洗碗......"这首脍炙人口的老歌道出了多少父母的期盼,又是多少儿女的遗憾.因为生活,因为工作,我们总是很忙,忙得没有时间回家,甚至打 ...
- 首发 | 用声音改变生活,标贝科技完成 A 轮 5000 万人民币融资
AI科技大本营获悉,日前,专注于智能语音交互技术及数据的"标贝科技"完成 A 轮 5000 万元人民币融资,本轮投资由深创投领投,恒生电子跟投. 值得注意的是,本轮的领投方深创投在 ...
- 标贝科技推出情感合成 TTS,让语音交互更有温度!
语音合成技术已进入到人们的日常生活,有声阅读.智能客服.智能家居等场景都已经出现了"它"的身影.有情感的声音,赋予机器生命感,让人机交互更美好.简单. 5月28日,标贝科技重磅推出 ...
- 直击标贝科技WAIC2019:深耕语音合成与数据服务 助力语音场景完美落地
8月29日,WAIC2019世界人工智能大会于上海世博中心&上海世博展览馆举办.本届大会以"智联世界 无限可能"为主题,以"高端化.国际化.专业化.市场化.智能化 ...
- 标贝科技亮相2019中国互联网大会 解决语音合成定制需求痛点
2019中国互联网大会于7月9日-11日在北京国家会议中心举行.本次大会以"创新求变再出发"为主题,开设物联网.人工智能等系列分支论坛,汇聚国内重点科研机构及众多知名互联网及人工智 ...
- 手把手教你用JAVA实现“语音合成”功能(文字转声音)标贝科技
手把手教你用JAVA实现"语音合成"功能(文字转声音)标贝科技 前言 什么是语音合成? 将文本转换成自然流畅的语音,本篇文章将介绍"实时在线合成"(文本长度不得 ...
最新文章
- 给VIM安装YouCompleteMe插件
- 刀模图是什么意思_“吃鸡”光子公布神秘图,海岛图上有44个坐标,暗示信号值取消?...
- android 开发时遇到的各种问题1--Android双模(CDMA/GSM)手机短信相关
- 从零开始小说 html,从零开始的HTML生活
- C++的一些知识点摘抄(创建基本类 高级类)
- 关于NSIS脚本的Demo
- 演练 开心庄园 1002
- java开发自学手册 pdf_Java项目开发实例自学手册 PDF_IT教程网
- 陕西年内建成1万个5G基站,实现全省所有地级市覆盖5G网络
- 《穷查理宝典》读书摘要和思维导图
- ANC降噪蓝牙耳机软件工程的数学原理
- 国开文学英语赏析 2021春(2021年7月)
- 搜索引擎的查找算法实现
- 安装了linux后win10键盘失灵,win10系统安装后笔记本键盘失灵不能用的解决方法
- 企业微信群:机器人定时提醒功能数据库配置化
- 被你们恶搞多年,鲁迅终于坐不住了:求求你们了!我没说过!
- Web前端学习笔记07:CSS_高级技巧_定位
- 3D 打印没那么玄乎
- python爬财务数据_会计终于不用被老板催着做报表,现在95%的财务都在悄悄办这事了!...
- (ROC-RK3568-PC) 裸机24_驱动VOP2显示自绘画面
热门文章
- 怎样做小游戏挖金子(VC,源码2)
- 抖音热门歌曲 改变视频文件的md5
- ERP系统物料清单管理:自由选配,随需应变!
- Java封装redis工具类RedisUtils,以及在@Postconstruct注解中调用redis可能出现redisTemplate空指针异常
- 从FC到Wii 24年来游戏机CPU发展历程回顾
- SSHPASS 源码分析
- flutter和原生交互
- java nonnull,java – “如果函数返回非null,则为NonNull”?
- opencv 学习笔记五 二维离散卷积
- 蓝格赛中国启用Informatica PIM系统,加速多渠道战略和数字化转型