微信小程序和uniapp对比区别

UniApp 与微信小程序对比

1. 开发环境

  • 微信小程序:使用微信开发者工具
  • UniApp:主要使用 HBuilderX,但也可以使用 VS Code 等其他编辑器

2. 项目结构

  • 微信小程序:pages, utils, app.js, app.json, app.wxss
  • UniApp:pages, static, App.vue, main.js, manifest.json, pages.json

3. 页面文件

  • 微信小程序:.wxml, .wxss, .js, .json
  • UniApp:.vue (包含 template, script, style)

4. 基础组件

微信小程序 UniApp 说明
view view 视图容器,类似于 div
text text 文本组件
image image 图片组件
button button 按钮组件
input input 输入框组件
scroll-view scroll-view 可滚动视图区域
swiper swiper 滑块视图容器

5. 生命周期

微信小程序 UniApp (Vue3 组合式 API)
onLoad onLoad
onShow onShow
onReady onReady
onHide onHide
onUnload onUnload
onPullDownRefresh onPullDownRefresh
onReachBottom onReachBottom

注:UniApp 在 Vue3 组合式 API 中,这些钩子需要单独引入使用。

6. 数据绑定与更新

  • 微信小程序:

    javascript 复制代码
    Page({
      data: {
        message: 'Hello'
      },
      changeMessage() {
        this.setData({ message: 'Hi' })
      }
    })
  • UniApp (Vue3 组合式 API):

    javascript 复制代码
    import { ref } from 'vue'
    
    export default {
      setup() {
        const message = ref('Hello')
        
        function changeMessage() {
          message.value = 'Hi'
        }
        
        return {
          message,
          changeMessage
        }
      }
    }

7. 条件渲染

  • 微信小程序:wx:if, wx:elif, wx:else
  • UniApp:v-if, v-else-if, v-else

8. 列表渲染

  • 微信小程序:wx:for, wx:key
  • UniApp:v-for, :key

9. 事件处理

  • 微信小程序:bindtap, catchtap
  • UniApp:@click, @tap

10. 路由导航

  • 微信小程序:

    javascript 复制代码
    wx.navigateTo({ url: '/pages/about/about' })
  • UniApp:

    javascript 复制代码
    uni.navigateTo({ url: '/pages/about/about' })

11. 网络请求

  • 微信小程序:

    javascript 复制代码
    wx.request({
      url: 'https://api.example.com/data',
      success(res) {
        console.log(res.data)
      }
    })
  • UniApp:

    javascript 复制代码
    uni.request({
      url: 'https://api.example.com/data',
      success(res) {
        console.log(res.data)
      }
    })

12. 存储

  • 微信小程序:wx.setStorageSync, wx.getStorageSync
  • UniApp:uni.setStorageSync, uni.getStorageSync

13. 组件创建和使用

  • 微信小程序:使用 Component() 创建,在 json 文件中引入
  • UniApp:创建 .vue 文件,在父组件中引入并注册

14. 全局配置

  • 微信小程序:app.json
  • UniApp:pages.json, manifest.json

15. 条件编译

  • 微信小程序:无内置条件编译,需要使用其他方法
  • UniApp:内置条件编译,如 #ifdef MP-WEIXIN, #endif

注意:UniApp 不仅支持编译到微信小程序,还支持其他平台如 H5、App 等,因此在某些方面会比微信小程序更加灵活和强大。

相关推荐
计算机-秋大田6 小时前
基于微信小程序的电子竞技信息交流平台设计与实现(LW+源码+讲解)
spring boot·后端·微信小程序·小程序·课程设计
Stanford_110613 小时前
C++中常用的十大排序方法之4——希尔排序
c++·算法·微信小程序·排序算法·微信公众平台·twitter·微信开放平台
林涧泣14 小时前
【Uniapp-Vue3】解决uni-popup弹窗在安全区显示透明问题
前端·vue.js·uni-app
Colinnian17 小时前
微信小程序中在一个大边框里给每个小边框均匀分配空间
微信小程序·小程序·notepad++
一 乐18 小时前
基于微信小程序的酒店管理系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·微信小程序·酒店管理系统
曾经的三心草2 天前
小程序-基础加强-自定义组件
微信小程序·自定义组件·基础加强
你爱写程序吗(新H)2 天前
基于微信小程序的停车场管理系统设计 停车场微信小程序的设计与实现 (源码+文档)
java·spring boot·微信小程序·小程序
baby_hua2 天前
2021版小程序开发4——基础加强
微信小程序
寰宇软件2 天前
PHP场馆预定系统小程序
小程序·uni-app·vue·php
Stanford_11063 天前
物联网智能项目之——智能家居项目的实现!
物联网·学习·微信小程序·智能家居·微信公众平台·twitter·微信开放平台