免费试用

跨平台小程序在线开发工具,用做网页的技术做小程序,兼容微信、支付宝、抖音、快手、百度等主流小程序平台!

uni-app 开发微信小程序

uni-app 是一个跨平台开发框架,能够将一份代码同时编译成各个平台的应用,包括微信小程序等。下面详细介绍 uni-app 在开发微信小程序时的工作原理。

## uni-app 的架构

uni-app 框架基于 Vue.js 开发,它为开发团队提供了一站式的解决方案,包括了前端框架、开发工具和发布平台。uni-app 把小程序原生 API 封装成一套统一的 API,在开发时可以根据条件选择调用底层 API 还是微信小程序 API。

下面是 uni-app 的架构图:

![uni-app 架构图](https://cdn.nlark.com/yuque/0/2022/png/3530867/1644367366193-4d559824-5f55-4599-a75c-d5794cafec35.png)

uni-app 的架构可分为三层:

- 面向开发者的框架层:提供了丰富的组件和 API,以及开发工具集成成的开发环境;

- 面向平台的渲染层:uni-app 框架会将运行在特定平台上需要执行的代码编译成对应平台所能执行的代码,同时以统一的方式提供对应平台的原生能力;

- 原生平台 SDK 层:用于让 uni-app 能够在各个不同的平台上编译运行。

## 微信小程序开发的原理

从 uni-app 框架到微信小程序,涉及了两个平台:

1. uni-app 平台

2. 微信小程序平台

### uni-app 平台

uni-app 平台的架构图如下所示:

![uni-app 平台](https://cdn.nlark.com/yuque/0/2022/png/3530867/1644368156764-30ba490a-b277-4e09-814b-2cf9e6c69ec0.png)

uni-app 开发者会使用到 IDE 开发工具或命令行工具进行编写程序,并在平台上运行同步开发的调试工具。运行时通过 Runtime 层将 vue 模板编译成对应平台的代码。

### 微信小程序平台

微信小程序的架构图如下所示:

![](https://cdn.nlark.com/yuque/0/2022/png/3530867/1644368276823-ac007eb1-1d5c-4474-bf1b-9d7f655b285e.png)

Micro-parser 负责解析 JS、WXML 和 WXSS 文件,解析后得到相应的 AST。在运行时,会通过小程序的 API 将解析后的 AST 渲染到屏幕上,用户和开发者就可以看到渲染后的效果。

### 微信小程序与 uni-app 的对接

接下来,从 uni-app 平台出发,介绍微信小程序与 uni-app 是如何对接的。

#### 小程序的环境兼容处理

微信小程序官方原始的接口与 uni-app 平台赋予了很多基于 Web 标准的 API,同时貌似也对原生的接口做了一些封装。uni-app 的开发者在使用习惯和性能方面也与原始的小程序开发者的体验不相同。因此 uni-app 把原小程序接口进行了再封装,并提供了对应的框架接口。

比如 uni-app 将触摸事件封装成了 vue 的 DOM 事件,又将小程序的 wxss 编译成了 CSS 标准的语法,封装出了 Page、Component 和 App 等不同快照(snapshot)形式的组件。

#### 编译

uni-app 中的对应同名组件是在渲染树与WXML 渲染树匹配时使用的。在当前这个组件加载时,会在开发环境先去加载它们在 WXML 上的子树,之后认真看上去匹配它在注册中定义的 Component 部分。这里是 Vue.js 组件渲染分离的体现。

下面是 uni-app 编译流程:

- 通过 babel 将源码转化为标准的 ES5 代码

- 将 HTML、CSS、JS 同时编译成小程序可直接使用的代码

- 使用微信 IDE 相应的工具进行编译打包

#### 运行

运行时 uni-app 用代码根据小程序 Page、Component 和 App 注册项自动创建生成内部的 Vue 实例,完整地将当前页面、组件等进行封装。

总之,uni-app 知道如何编译一个小程序,将组件编译为如何从小程序实例上的属性或方法等相关的访问。这是一个函数,会将小程序的属性作为组件的属性传入 vue 实例,然后渲染组件中的子结构。

## 总结

综上所述,uni-app 使用一些框架技巧以及原生的小程序 API,在编写 App 和小程序时,采用了同一份代码,运行时自动适配平台。因此,uni-app 将小程序变得更加简单方便,这种技术架构对于使用 uni-app 开发微信小程序的开发者来说,意味着他们不再需要为每个平台编写单独的代码,节省了很多时间和精力。


相关知识:
怎么样使用百度app智能小程序开发语言
百度智能小程序是一种轻量级的应用程序,用户无需下载安装即可使用。它基于HTML5、CSS3和JavaScript开发,具有跨平台的特点,能够在百度App中直接运行,为用户提供更便捷的服务和体验。在本文中,我将详细介绍百度智能小程序的开发语言和原理。1. 开
2023-08-23
安徽汽车美容小程序开发制作有限公司怎么样
安徽汽车美容小程序开发制作有限公司是一家专注于为汽车美容行业打造小程序的公司。其主要业务包括小程序的设计、开发、部署和运营。小程序是一种基于微信平台开发的应用程序,它具有轻便、高效、易用的特点,可以在微信社交软件内部直接运行,无需下载和安装。由于微信拥有庞
2023-08-09
安卓小程序开发工具怎么用
安卓小程序是一种轻量级应用,其专门为安卓平台设计,与微信小程序相比,安卓小程序开发的工具比较多样化,包括使用原生开发,使用Hybrid(原生 + Web混合)开发和使用Web开发的方式。下面详细介绍安卓小程序开发工具及其运作原理。安卓小程序开发工具安卓小程
2023-08-09
python如何开发小程序
Python 是一种高级编程语言,常用于 Web 应用程序开发、数据分析、数据科学和人工智能。开发者可以使用 Python 来创建许多不同类型的应用程序,包括小程序。Python 是一种简单、易学的编程语言,具有丰富的标准库和大量的第三方库。通过这些库,P
2023-08-09
app小程序开发公司累吗
开发一个app或小程序不仅需要技术方面的专业知识,还需要耗费大量的人力、物力和财力,所以开发公司往往面临各种挑战和困难,在开发过程中需要时刻保持高度的警觉和灵活应对。首先,开发应用程序的公司需要面对的是市场竞争的压力。现在各种应用程序如雨后春笋般涌现,这些
2023-08-09
3微信小程序开发
微信小程序是一种新型的应用形态,也是一种全新的技术栈,它基于微信平台开发,可以在微信中直接运行。微信小程序可以轻松地实现微信生态系统中的多种功能,如微信支付、社交分享、微信接口等等。同时,微信小程序还有着很多优势,如体积小、启动快、无需安装等等。本文将详细
2023-08-09
js文件封装exe
JavaScript(JS)与可执行文件(.exe)之间有着一定的差异,因为它们分别属于不同的技术领域。JavaScript是一种脚本语言,主要应用于Web开发领域,运行在Web浏览器中;而可执行文件(.exe)一般是Windows操作系统中使用的二进制程
2023-05-26
微信小程序开发工具类排行
在微信小程序开发中,开发工具是非常重要的,因为通过开发工具我们可以完成小程序的开发、调试和发布。本文将介绍一些常见的微信小程序开发工具,以及它们的原理和功能。1. 微信开发者工具微信开发者工具是微信官方推出的一款小程序开发工具,可以帮助开发人员进行开发、测
2023-05-26
微信小程序开发工具的一些坑
微信小程序开发工具是一款跨平台的开发工具,旨在帮助开发者快速地开发和调试微信小程序。这款工具包含了多个模块,如代码编辑器、资源管理器、调试器等等,其中也有一些需要注意的坑点。一、开发工具版本微信小程序开发工具有两种版本,分别是稳定版和测试版。虽然测试版会提
2023-05-26
头条号小程序开发工具
头条号小程序是今日头条推出的一种快速开发小程序的平台,依托于今日头条的庞大流量,吸引了越来越多的开发者使用。头条号小程序开发工具是用来创建、开发和管理头条号小程序的集成开发工具。本文将对头条号小程序开发工具的原理和详细介绍进行阐述。一、头条号小程序开发工具
2023-05-26
河池旅游小程序开发工具
河池旅游小程序是一款专注于河池旅游、景点、美食、住宿等信息推荐的小程序。开发工具是指用于开发小程序的软件或平台,如微信开发者工具等。在这篇文章中,我将介绍河池旅游小程序的开发工具,并讨论其原理和优势。一、微信小程序的特点1. 无需下载:小程序是基于微信内置
2023-05-22
阿里小程序开发工具是什么
阿里小程序开发工具是一种基于阿里云的小程序开发工具,可以帮助开发者更快速、更高效地开发出小程序应用。下面将从原理和详细介绍两方面,对阿里小程序开发工具进行阐述。一、原理阿里小程序开发工具采用了一种基于云架构的开发模式。也就是说,开发者可以在云端进行开发和调
2023-05-22