免费试用

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

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 开发微信小程序的开发者来说,意味着他们不再需要为每个平台编写单独的代码,节省了很多时间和精力。


相关知识:
鞍山本地小程序开发制作服务平台
随着移动互联网的飞速发展,小程序作为一种不断崭新的移动应用形式,正逐渐成为各行各业的重要营销渠道和业务平台。鞍山本地小程序开发制作服务平台,是一家集小程序前端开发、设计、策划、运营于一体的综合性服务平台,可以帮助企业快速搭建一个全新的小程序平台。鞍山本地小
2023-08-09
阿里云云开发微信小程序的方法
阿里云作为国内领先的云计算服务提供商,为微信小程序提供了完整的开发和部署解决方案,实现了云开发和小程序的深度结合,让开发者更方便地搭建应用平台。阿里云云开发微信小程序的方法主要涉及以下几个方面:一、云开发环境的搭建阿里云提供了云开发控制台,可用于创建并管理
2023-08-09
安康智慧景区小程序开发
随着旅游业的快速发展,越来越多的人选择去景区游玩。而随着智能手机的普及,人们在旅游时获取信息、导航、支付、评论等方面都离不开手机。因此,景区小程序的开发变得越来越重要。安康智慧景区小程序是一款基于微信平台的智能应用程序,旨在提供优质的旅游和自然景观资源、景
2023-08-09
xia小程序开发
小程序是一种新型的移动应用,它不需要下载安装即可使用,具有轻便、快速等特点。小程序开发主要涉及前端和后端两部分,下面将为大家介绍小程序的开发原理和详细步骤。一、小程序开发的原理小程序开发的原理主要分为前端和后端两个部分。前端开发:小程序前端开发采用的是基于
2023-08-09
vue对接小程序开发
Vue是一种流行的JavaScript框架,它已经成为创建现代Web应用程序的首选框架之一。同时,微信小程序是一种具有独特体验的应用程序,由于拥有自身的开发标准和API,需要与Vue整合时需要注意一些问题。在Vue应用中,我们可以通过使用构建工具(webp
2023-08-09
app小程序开发的轻吧
小程序,指的是不需要下载安装即可使用的应用程序,简称“小程序”,与传统的App不同,小程序既无需下载安装,也无需占用手机空间,用户扫描或搜索即可直接进入使用。小程序的开发一般分为前端和后端两部分。前端采用WXML + WXSS + JavaScript语言
2023-08-09
android 微信小程序开发
随着移动互联网的快速发展,小程序成为了一个越来越受欢迎的应用形态。它可以轻松快速地在微信、支付宝等平台上实现简单的应用逻辑,同时也拥有比普通网页更好的用户交互和体验。本文主要介绍在 Android 平台上如何开发微信小程序,让读者了解其工作原理和开发流程。
2023-08-09
java打包转换成exe
在本教程中,我们将了解如何将Java应用程序打包并转换成exe文件。通过这种方式,用户无需了解Java环境细节,就可以快速轻松地运行程序。我们需要一个转换工具来帮助我们完成这个任务,本教程主要使用Launch4j来完成这个过程。### 1. 前提条件在将J
2023-05-26
小程序开发工具哪个好用
在微信小程序开发中,小程序开发工具可以帮助开发者完成小程序代码的编写、调试、上传等工作。目前市面上有很多小程序开发工具,但是开发效率和技术支持等各方面存在差异。那么,小程序开发工具哪个好用呢?本文将从原理和详细介绍两方面进行讨论,帮助开发者了解并选择合适的
2023-05-26
微信小程序的开发工具怎么用
微信小程序是由腾讯公司开发的一款轻应用程序,通过小程序开发者工具进行开发和发布,开发者可以在没有安装的情况下直接使用小程序。这篇文章将详细介绍微信小程序的开发工具的使用方法和原理。一、微信小程序开发工具基本介绍微信小程序开发工具是一款专为微信小程序开发者准
2023-05-26
微信小程序开发工具运行结果怎么复制图片
微信小程序开发工具是一款方便开发者进行微信小程序开发的工具,它除了提供代码编写、运行测试的基本功能外,还支持一些常用的工具功能,如调试、日志查看、网络请求等。其中,有时候我们需要将小程序运行结果的截图或图片复制下来,以用于文档编写、报告制作等需要。本篇文章
2023-05-26
北京企业办公小程序开发工具有哪些功能
企业办公小程序是一种集成了企业内部管理和业务流程的移动应用,由于其具有便捷性和高效性而广受欢迎。下面就来介绍一下北京企业办公小程序开发工具的功能以及其原理。一、功能介绍1. 实现企业管理功能企业办公小程序可以实现企业各项管理功能,包括人力资源管理、业务办理
2023-05-22