标贝科技 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多平台融合【入门】(标贝科技)相关推荐

  1. kaldi新手入门及语音识别的流程(标贝科技)

    kaldi新手入门及语音识别的流程(标贝科技) 欢迎体验标贝语音开放平台 地址:https://ai.data-baker.com/#/?source=qaz123 (注:填写邀请码hi25d7,每日 ...

  2. 标贝科技推出「留声机」TTS方案,高还原、个性化声效提升交互意愿

    3 月 5 日,标贝科技推出全新 「留声机」,该方案具有高原度复刻效果,用户只需 5 分钟左右即可完成录制,训练过程全自动化处理,大约 2 小时后,即可拥有媲美原声声音的个性化模型,轻松实现文本转语音 ...

  3. 标贝科技登全球语音大赛舞台Blizzard Challenge做精彩开场发言

    继语音论文成功入选并亮相全球顶级语音学术会议INTERSPEECH2019后,标贝科技再登全球语音大赛舞台Blizzard Challenge2019(译为暴雪挑战赛). 9月23日,全球语音合成领域 ...

  4. 标贝科技声音克隆技术赋能 定制语音功能让陪伴触手可及

    "常回家看看,回家看看,哪怕帮妈妈刷刷筷子洗洗碗......"这首脍炙人口的老歌道出了多少父母的期盼,又是多少儿女的遗憾.因为生活,因为工作,我们总是很忙,忙得没有时间回家,甚至打 ...

  5. 首发 | 用声音改变生活,标贝科技完成 A 轮 5000 万人民币融资

    AI科技大本营获悉,日前,专注于智能语音交互技术及数据的"标贝科技"完成 A 轮 5000 万元人民币融资,本轮投资由深创投领投,恒生电子跟投. 值得注意的是,本轮的领投方深创投在 ...

  6. 标贝科技推出情感合成 TTS,让语音交互更有温度!

    语音合成技术已进入到人们的日常生活,有声阅读.智能客服.智能家居等场景都已经出现了"它"的身影.有情感的声音,赋予机器生命感,让人机交互更美好.简单. 5月28日,标贝科技重磅推出 ...

  7. 直击标贝科技WAIC2019:深耕语音合成与数据服务 助力语音场景完美落地

    8月29日,WAIC2019世界人工智能大会于上海世博中心&上海世博展览馆举办.本届大会以"智联世界 无限可能"为主题,以"高端化.国际化.专业化.市场化.智能化 ...

  8. 标贝科技亮相2019中国互联网大会 解决语音合成定制需求痛点

    2019中国互联网大会于7月9日-11日在北京国家会议中心举行.本次大会以"创新求变再出发"为主题,开设物联网.人工智能等系列分支论坛,汇聚国内重点科研机构及众多知名互联网及人工智 ...

  9. 手把手教你用JAVA实现“语音合成”功能(文字转声音)标贝科技

    手把手教你用JAVA实现"语音合成"功能(文字转声音)标贝科技 前言 什么是语音合成? 将文本转换成自然流畅的语音,本篇文章将介绍"实时在线合成"(文本长度不得 ...

最新文章

  1. 给VIM安装YouCompleteMe插件
  2. 刀模图是什么意思_“吃鸡”光子公布神秘图,海岛图上有44个坐标,暗示信号值取消?...
  3. android 开发时遇到的各种问题1--Android双模(CDMA/GSM)手机短信相关
  4. 从零开始小说 html,从零开始的HTML生活
  5. C++的一些知识点摘抄(创建基本类 高级类)
  6. 关于NSIS脚本的Demo
  7. 演练 开心庄园 1002
  8. java开发自学手册 pdf_Java项目开发实例自学手册 PDF_IT教程网
  9. 陕西年内建成1万个5G基站,实现全省所有地级市覆盖5G网络
  10. 《穷查理宝典》读书摘要和思维导图
  11. ANC降噪蓝牙耳机软件工程的数学原理
  12. 国开文学英语赏析 2021春(2021年7月)
  13. 搜索引擎的查找算法实现
  14. 安装了linux后win10键盘失灵,win10系统安装后笔记本键盘失灵不能用的解决方法
  15. 企业微信群:机器人定时提醒功能数据库配置化
  16. 被你们恶搞多年,鲁迅终于坐不住了:求求你们了!我没说过!
  17. Web前端学习笔记07:CSS_高级技巧_定位
  18. 3D 打印没那么玄乎
  19. python爬财务数据_会计终于不用被老板催着做报表,现在95%的财务都在悄悄办这事了!...
  20. (ROC-RK3568-PC) 裸机24_驱动VOP2显示自绘画面

热门文章

  1. 怎样做小游戏挖金子(VC,源码2)
  2. 抖音热门歌曲 改变视频文件的md5
  3. ERP系统物料清单管理:自由选配,随需应变!
  4. Java封装redis工具类RedisUtils,以及在@Postconstruct注解中调用redis可能出现redisTemplate空指针异常
  5. 从FC到Wii 24年来游戏机CPU发展历程回顾
  6. SSHPASS 源码分析
  7. flutter和原生交互
  8. java nonnull,java – “如果函数返回非null,则为NonNull”?
  9. opencv 学习笔记五 二维离散卷积
  10. 蓝格赛中国启用Informatica PIM系统,加速多渠道战略和数字化转型