uni-app 系统学习,从入门到实战(二)—— 项目结构解析

news/2025/2/25 5:47:48

全篇大概 2000 字(含代码),建议阅读时间 10min

一、UniApp 目录结构详解

        UniApp 基于 Vue.js 开发,其目录结构遵循约定大于配置的原则,以下是一个标准项目的核心目录结构:

pages # 页面目录(核心)
index # 首页
index.vue # 页面组件
index.scss # 页面样式
static # 静态资源(图片、字体等)
components # 自定义组件
uni_modules # 插件市场安装的模块
common # 公共工具(JS、CSS)
App.vue # 应用入口组件
main.js # 应用入口脚本
pages.json # 全局页面配置(核心)
manifest.json # 应用发布配置(核心)
uni.scss # 全局样式变量
1.1 核心目录说明
  1. pages 目录

    • 每个子目录对应一个页面,必须包含 .vue 文件。

    • 页面路径需在 pages.json 中注册后才能访问。

  2. static 目录

    • 存放静态资源(如图片、字体),通过绝对路径 /static/logo.png 引用。

    • 打包时会直接复制到输出目录,不建议存放大型文件

  3. components 目录

    • 存放全局复用组件,通过 @/components/xxx.vue 引入。


二、pages.json:页面路由与全局样式配置

        pages.json 是 UniApp 的核心配置文件,负责管理页面路由、导航栏样式、底部 TabBar 等全局设置。

2.1 基本结构示例
{
  "pages": [
    {
      "path": "pages/index/index",
      "style": {
        "navigationBarTitleText": "首页",
        "enablePullDownRefresh": true
      }
    }
  ],
  "globalStyle": {
    "navigationBarTextStyle": "black",
    "navigationBarBackgroundColor": "#FFFFFF"
  },
  "tabBar": {
    "list": [
      {
        "pagePath": "pages/index/index",
        "text": "首页"
      }
    ]
  }
}
2.2 核心配置项解析
  • pages 数组

    • path: 页面路径(相对于项目根目录)

    • style: 页面独有样式配置(覆盖全局配置)

  • globalStyle

    • 全局导航栏、背景色、下拉刷新等样式配置。

  • tabBar

    • 底部导航栏配置,最多支持 5 个 Tab。

2.3 最佳实践
  • 使用 condition 字段实现动态路由(如根据用户权限显示不同页面)。

  • 通过 easycom 配置自动引入组件,避免手动注册。


三、manifest.json:应用发布与多端适配

    manifest.json 是应用的发布配置文件,用于配置应用名称、图标、启动页、权限等平台相关设置。

3.1 基本结构示例
{
  "name": "MyApp",
  "appid": "__UNI__XXXXXX",
  "versionName": "1.0.0",
  "mp-weixin": {
    "appid": "wx1234567890",
    "permission": {
      "scope.userLocation": {
        "desc": "需要获取您的位置信息"
      }
    }
  },
  "h5": {
    "title": "My H5 App",
    "router": {
      "mode": "history"
    }
  }
}
3.2 多平台配置策略
  • 公共配置nameversionNameappid 等全局生效。

  • 平台专属配置:如 mp-weixin(微信小程序)、h5app(原生 App)等节点。

3.3 关键配置项
  • 图标与启动页

    "icons": {
      "android": "/static/logo.png",
      "ios": "/static/logo.png"
    },
    "splashscreen": {
      "alwaysShowBeforeRender": false
    }
  • 权限声明(微信小程序)

    "mp-weixin": {
      "permission": {
        "scope.userLocation": {
          "desc": "获取位置用于导航功能"
        }
      }
    }
     

四、开发与发布流程优化

  1. 环境区分

    • 通过 process.env.NODE_ENV 区分开发与生产环境。

    • 在 manifest.json 中配置不同环境的 API 地址。

  2. 性能优化

    使用 分包加载 减少首屏体积:
// pages.json
"subPackages": [
  {
    "root": "subpages",
    "pages": [ ... ]
  }
]
  1. 多平台发布

    • 通过 HBuilderX 的 发行菜单 一键生成各平台代码包。

    • 针对不同平台调整 manifest.json 中的配置(如微信小程序的 appid)。


五、常见问题与解决方案

  1. 页面白屏

    • 检查 pages.json 中的路径是否正确。

    • 确保页面组件包含 <template><script><style> 标签。

  2. 静态资源加载失败

    • 使用绝对路径 /static/...,避免相对路径。

    • 检查文件是否被正确复制到 dist 目录。

  3. 跨平台样式兼容

    • 使用 uni.scss 定义全局样式变量。

    • 通过条件编译实现平台差异化样式:

/* #ifdef H5 */
.header { height: 44px; }
/* #endif */

总结

掌握 UniApp 的目录结构与核心配置文件(pages.json 和 manifest.json)是开发跨平台应用的关键。通过合理配置,可以实现:

  • 高效路由管理

  • 多平台差异化适配

  • 一键打包发布


http://www.niftyadmin.cn/n/5865046.html

相关文章

springboot集成jackson-dataformat-xml实现发送XML请求和XML响应参数处理

背景 最近在做发票相关的业务&#xff0c;需要对接第三方进行开发票等一系列操作&#xff0c;对方的系统是较老系统&#xff0c;需要采用XML的请求方式。 思路 一般来说&#xff0c;基于springboot的项目采用的都是JSON格式的请求参数和响应参数&#xff0c;因此需要做一个转…

基金基础知识

一、基金的本质与价值 定义&#xff1a; 基金是通过集合投资者资金&#xff0c;由专业管理人&#xff08;基金经理&#xff09;进行多元化投资&#xff08;如股票、债券等&#xff09;的金融工具&#xff0c;收益按持有份额分配。 核心优势&#xff1a; 分散风险&#xff1a;…

AI写代码工具赋能前端开发:高效学习与应用AI前端框架

近年来&#xff0c;人工智能技术飞速发展&#xff0c;深刻地改变着软件开发的模式。在前端开发领域&#xff0c;AI写代码工具的兴起更是掀起了一场革命&#xff0c;为开发者带来了前所未有的效率提升和全新的开发体验。掌握AI前端框架已不再是锦上添花&#xff0c;而是提升竞争…

《Effective Objective-C》阅读笔记(下)

目录 内存管理 理解引用计数 引用计数工作原理 自动释放池 保留环 以ARC简化引用计数 使用ARC时必须遵循的方法命名规则 变量的内存管理语义 ARC如何清理实例变量 在dealloc方法中只释放引用并解除监听 编写“异常安全代码”时留意内存管理问题 以弱引用避免保留环 …

第5章 软件工程(二)

5.3 软件设计 需求阶段解决“做什么”的问题&#xff0c;而软件设计阶段解决“怎么做”的问题。软件设计分为结构化设计与面向对象设计。 5.3.1 结构化设计 结构化设计(SD)是一种面向数据流的方法&#xff0c;其目的在于确定软件结构。它以SRS和SA阶段所产生的DFD和数据字典…

Gin从入门到精通(八)身份验证与授权(JWT)

身份验证与授权(JWT) Gin 支持通过 JWT&#xff08;JSON Web Token&#xff09;来实现用户的身份验证。通过中间件验证用户的身份后&#xff0c;可以控制资源的访问权限。 JWT 认证流程 : 1. 用户登录 → 服务端验证 → 生成 JWT → 返回 Token 2. 客户端存储 Token → 后…

大模型架构与训练方向

一、核心知识领域 ‌模型架构设计‌ 掌握Transformer、MoE&#xff08;Mixture-of-Experts&#xff09;、RetNet等主流架构的原理与实现细节&#xff0c;需深入理解注意力机制、位置编码、稀疏激活等技术‌13。学习多模态融合架构&#xff08;如CLIP、Flamingo&#xff09;&…

Unity3D实现编辑器截屏Preview窗口,并生成图片PNG

系列文章目录 unity工具 文章目录 系列文章目录👉前言👉一、Preview窗口👉二、手动选择预制体截屏👉二、自动选择预制体截屏👉壁纸分享👉总结👉前言 想要在Unity编辑器中截取Preview窗口的截图,并生成图片的代码。 有时候可能会需要此模型的图片,又不想P图,…