免费试用

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

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
viiva购app开发小程序
Viiva购是一款基于微信小程序的购物应用,让用户可以通过小程序购买商品,进行支付和收货等操作。它的主要运作流程流程包括用户浏览商品、添加购物车、下单支付、商家发货和用户确认收货。Viiva购采用了类似于Vue.js框架的MVVM开发模式,同时利用了微信小
2023-08-09
pb开发的聊天小程序
pb开发的聊天小程序,是基于谷歌开源协议protobuf的一个轻量级的即时通讯小程序,主要特点是高效、稳定、安全,支持多种消息类型和实时的消息推送。如何实现?首先,我们需要了解什么是protobuf。它是一种由谷歌开发的数据序列化协议,可以将结构化的数据转
2023-08-09
java微信小程序开发文档
Java 微信小程序开发文档微信小程序开发是近年来非常火热的技术领域,而作为 Java 开发人员,我们可以使用一些 Java 框架和技术来进行微信小程序开发。本文将介绍如何使用 Java 来开发微信小程序,包括微信小程序原理和详细介绍。一、微信小程序原理微
2023-08-09
hbuilderx 开发微信小程序
HBuilderX 是基于 VS Code 的前端开发工具,可以快速开发多端应用,其中包括微信小程序。下面是关于如何在 HBuilderX 中开发微信小程序的详细介绍。一、开发环境的配置1. 安装 HBuilderX,并在插件市场中搜索并安装微信小程序插件
2023-08-09
app小程序开发的销售需要了解什么知识
App小程序是一种移动应用程序,它可以直接在手机、平板电脑等设备上运行,而不需要下载和安装。与传统应用程序相比,它具有轻便、易于开发、快速上线等优势,逐渐受到了越来越多消费者和企业的喜爱。如果你准备从事App小程序开发的销售工作,你需要了解如下的知识。一、
2023-08-09
运城免费小程序开发工具
运城免费小程序开发工具,是运城市为了鼓励小微企业和创业者积极开发小程序而推出的一款免费开发工具,旨在提高小微企业和创业者的竞争力和品牌形象。下面将详细介绍该开发工具的原理和具体操作步骤。一、原理运城免费小程序开发工具基于小程序平台的开发原理,使用前端技术H
2023-05-26
小程序和小游戏开发工具一样吗
小程序和小游戏都是运行在微信平台上的应用程序,但是它们的开发工具是不一样的。本篇文章将会从原理和详细介绍两方面进行探讨。原理小程序和小游戏的底层框架都是使用WebGL渲染引擎和JavaScript脚本语言。小程序和小游戏的主要区别在于它们的运行环境不同,小
2023-05-26
微信开发工具打开本地小程序代码
微信开发工具是一款专门用于开发和调试微信小程序的工具软件,提供了一系列的功能来方便开发者调试以及发布小程序。在使用微信开发工具时,开发者可以方便地将自己本地的小程序代码通过工具打开,进行调试以及修改等操作。下面将介绍微信开发工具打开本地小程序代码的原理和详
2023-05-26
微信小程序开发工具调用函数失败
微信小程序开发工具是一款非常强大的开发工具,但是,有时在使用过程中会遇到一些问题,比如调用函数失败的情况。本文将从原理和详细介绍两方面来讲解这个问题。一、原理在微信小程序开发中,调用函数失败的原因可能有很多种。通常,它会是由于以下几个主要原因引起的。1.
2023-05-26
微信小程序开发工具多行注释代码
在微信小程序开发过程中,注释是非常重要的,可以帮助开发者理顺逻辑,方便其他人维护和修改代码。然而,在小程序开发工具中,如果我们需要注释多行代码,可能会发现使用常规的注释方法无法达到我们的目的。下面将介绍在微信小程序开发工具中如何实现多行注释。在介绍具体操作
2023-05-26