diff --git a/docs/tutorial/README.md b/docs/tutorial/README.md index 6d0b31ad7066553fa9d1a651e3d06a3eff258a1f..b5b181aca806b6c9a0bf9a7b74ab4452133bcb79 100644 --- a/docs/tutorial/README.md +++ b/docs/tutorial/README.md @@ -1,9 +1,91 @@ -## 开发规范 +# uni-app组成和跨端原理 + +## 基本语言和开发规范 +uni-app代码编写,基本语言包括js、vue、css。以及ts、scss等css预编译器。 + +在app端,还支持原生渲染的[nvue](nvue-outline.md),以及可以编译为kotlin和swift的[uts](syntax-uts.md)。 + +DCloud还提供了使用js编写服务器代码的uniCloud云引擎。所以只需掌握js,你可以开发web、Android、iOS、各家小程序以及服务器等全栈应用。 为了实现多端兼容,综合考虑编译速度、运行性能等因素,```uni-app``` 约定了如下开发规范: -- 页面文件遵循 [Vue 单文件组件 (SFC) 规范](https://vue-loader.vuejs.org/zh/spec.html) +- 页面文件遵循 [Vue 单文件组件 (SFC) 规范](https://vue-loader.vuejs.org/zh/spec.html),即每个页面是一个.vue文件 - 组件标签靠近小程序规范,详见[uni-app 组件规范](/component/) -- 接口能力(JS API)靠近微信小程序规范,但需将前缀 ```wx``` 替换为 ```uni```,详见[uni-app接口规范](/api/) -- 数据绑定及事件处理同 ```Vue.js``` 规范,同时补充了App及页面的生命周期 -- 为兼容多端运行,建议使用flex布局进行开发 \ No newline at end of file +- 接口能力(JS API)靠近小程序规范,但需将前缀 `wx`、`my` 等替换为 `uni`,详见[uni-app接口规范](/api/) +- 数据绑定及事件处理同 `Vue.js` 规范,同时补充了App及页面的生命周期 +- 如需兼容app-nvue平台,建议使用flex布局进行开发 + +uni-app分`编译器`和`运行时(runtime)`。uni-app能实现一套代码、多端运行,是通过这2部分配合完成的。 + +编译器将开发者的代码进行编译,编译的输出物由各个终端的runtime进行解析,每个平台(Web、Android App、iOS App、各家小程序)都有各自的runtime。 + +## 编译器 +- 编译器运行在电脑开发环境。一般是内置在HBuilderX工具中,也可以使用独立的cli版。 +- 开发者按uni-app规范编写代码,由编译器将开发者的代码编译生成每个平台支持的特有代码 + * 在web平台,将.vue文件编译为js代码。与普通的vue cli项目类似 + * 在微信小程序平台,编译器将.vue文件拆分生成wxml、wxss、js等代码 + * 在app平台,将.vue文件编译为js代码。进一步,如果涉及uts代码: + + 在Android平台,将.uts文件编译为kotlin代码 + + 在iOS平台,将.uts文件编译为swift代码 +- 编译器分vue2版和vue3版 + * vue2版:基于wepback实现 + * vue3版:基于Vite实现。性能更快 +- 编译器支持条件编译,即可以指定某部分代码只编译到特定的终端平台。从而将公用和个性化融合在一个工程中。 +```js +// #ifdef App + console.log("这段代码只有在App平台才会被编译进去。非App平台编译后没有这段代码") +// #endif +``` + +更多编译器介绍参见:[编译器](compiler.md) + +## 运行时(runtime) +runtime不是运行在电脑开发环境,而是运行在真正的终端上。 + +uni-app在每个平台(Web、Android App、iOS App、各家小程序)都有各自的runtime。这是一个比较庞大的工程。 +- 在小程序端,uni-app的runtime,主要是一个小程序版的vue runtime,页面路由、组件、api等方面基本都是转义。 +- 在web端,uni-app的runtime相比普通的vue项目,多了一套ui库、页面路由框架、和uni对象(即常见API封装) +- 在App端,uni-app的runtime更复杂,可以先简单理解为DCloud也有一套小程序引擎,打包app时将开发者的代码和DCloud的小程序打包成了apk或ipa。当然,事实上DCloud确实有小程序引擎产品,供原生应用实现小程序化,[详见](https://nativesupport.dcloud.net.cn/README) + +uni-app runtime包括3部分:基础框架、组件、API。 +1. 基础框架: + * 包括语法、数据驱动、全局文件、应用管理、页面管理、js引擎、渲染和排版引擎等 + * 在web和小程序上,不需要uni-app提供js引擎和排版引擎,直接使用浏览器和小程序的即可。但app上需要uni-app提供 + * App的js引擎:App-Android上,uni-app的js引擎是v8,App-iOS是jscore + * App的渲染引擎:同时提供了2套渲染引擎,`.vue`页面文件由webview渲染,原理与小程序相同;`.nvue`页面文件由原生渲染,原理与react native相同。开发者可以根据需要自主选择渲染引擎。 +2. 组件: + * runtime中包括的组件只有基础组件,如``、`