典型的 Vue 3 项目目录结构详解

典型的 Vue 3 项目目录结构遵循模块化设计原则,旨在提升代码的可维护性和协作效率。以下基于主流脚手架(如 create-vue 或 Vite)生成的模板进行详解,结合核心文件和目录的功能说明:


📁 ​​根目录结构​

​目录/文件​ ​作用说明​ ​引用来源​
node_modules/ 存储项目依赖的 npm 包,由包管理器自动生成,​​禁止手动修改​​。
public/ 存放无需构建的静态资源(如 index.htmlfavicon.ico),文件会直接复制到最终输出目录。
src/ ​核心源代码目录​​,包含应用的所有业务逻辑和组件。
.gitignore 指定 Git 忽略的文件(如 node_modules/、构建产物)。
package.json 定义项目元数据、依赖项和脚本命令(如 npm run dev 启动开发服务器)。
vite.config.js Vite 构建工具的配置文件,支持路径别名、代理服务器等定制。
tsconfig.json TypeScript 项目的编译配置(如类型检查、模块解析规则)。

🖥️ ​src/ 目录详解​

​子目录/文件​ ​功能说明​ ​典型内容​
assets/ 存放需构建处理的静态资源(图片、字体、SCSS 文件),通过相对路径引用。 logo.png, global.scss
components/ ​可复用组件​ ​目录,按功能或模块分类(如 Common/Button.vueLayout/Navbar.vue)。 通用 UI 组件、业务组件
views/pages/ ​页面级组件​ ​目录,每个路由对应一个视图(如 Home.vueUser/Profile.vue)。 路由映射的页面组件
router/ 路由配置文件(index.js),定义路径与组件的映射关系。 createRouter() 配置
store/ 状态管理配置(Vuex 或 Pinia),集中管理全局状态(如用户登录信息)。 defineStore()(Pinia)或 createStore()(Vuex)
hooks/ 存放 Composition API 的自定义 Hook(如 useFetch.js),封装可复用逻辑。 数据请求、表单验证等逻辑
utils/ 工具函数库(如 request.js 封装 Axios 请求)。 日期格式化、权限校验等辅助函数
App.vue ​根组件​ ​,定义全局布局(如顶部导航栏),包含 <router-view> 渲染页面内容。 模板、样式及全局逻辑
main.js/main.ts ​应用入口文件​​,初始化 Vue 实例、挂载插件和全局配置。 createApp(App).use(router).use(store).mount('#app')

📄 ​​核心文件详解​

  1. public/index.html

    • ​作用​ :应用的主 HTML 模板,包含 <div id="app"> 作为 Vue 挂载点。

    • ​关键代码​

      复制代码
      <body> <div id="app"></div> <script type="module" src="/src/main.js"></script> </body>
  2. src/main.js

    • ​作用​

      • 创建 Vue 实例:const app = createApp(App)
      • 注册全局插件(路由、状态管理、UI 库)。
      • 挂载到 DOM:app.mount('#app')
    • ​示例​

      复制代码
      import { createApp } from 'vue'; import App from './App.vue'; import router from './router'; import ElementPlus from 'element-plus'; const app = createApp(App); app.use(router).use(ElementPlus).mount('#app');
  3. src/App.vue

    • ​结构​

      • <template>:定义根组件布局(如 <router-view> 渲染页面)。
      • <script>:编写组件逻辑(可选使用 Composition API)。
      • <style>:全局或局部样式。
    • ​典型代码​

      复制代码
      <template> <Header /> <router-view /> <Footer /> </template>

🔗 ​​文件协作关系​

  1. ​启动流程​
    index.html → 加载 main.js → 初始化 Vue 实例 → 挂载 App.vue → 渲染子组件。
  2. ​数据流​
    • ​路由​router/index.js 定义路径 → views/ 组件响应路由变化。
    • ​状态​store/ 管理全局数据 → 组件通过 useStore() 访问或修改状态。

⚙️ ​​扩展配置​

  • ​环境变量​ :根目录的 .env.development.env.production 配置环境参数。
  • ​测试目录​tests/ 存放单元测试(如 Vitest 或 Jest)。
  • ​样式规范​styles/ 存放全局样式、主题变量(如 variables.scss)。

📌 ​​命名规范建议​

  • ​组件文件​ :PascalCase(如 UserCard.vue)。
  • ​工具函数​ :camelCase(如 formatDate.js)。
  • ​目录​ :kebab-case(如 user-management/)。

通过合理组织目录结构和遵循规范,可显著提升团队协作效率和项目的长期可维护性。实际开发中,可结合项目规模调整结构(如微前端场景拆分多入口)

Vue 3项目的基本结构遵循Vue CLI创建的项目结构,或者使用Vite创建的项目结构。

以下是一个典型的Vue 3项目结构的概述:

bash 复制代码
my-vue3-project/
├── node_modules/             # 项目依赖
├── public/                   # 静态资源目录
│   ├── favicon.ico           # 网站图标
│   └── index.html            # 主HTML模板
├── src/                      # 源代码目录
│   ├── assets/               # 静态资源目录
│   │   ├── images/           # 图片资源
│   │   └── styles/           # 样式文件
│   ├── components/           # 公共组件目录
│   │   └── MyComponent.vue   # 示例组件
│   ├── views/                # 页面组件目录
│   │   └── Home.vue          # 示例页面组件
│   ├── App.vue               # 应用程序的根组件
│   ├── main.js               # 应用程序的入口文件
│   └── router/               # 路由配置目录
│       └── index.js          # 路由配置文件
├── tests/                    # 测试目录
│   └── unit/                 # 单元测试目录
│       ├── components/       # 组件单元测试
│       └── specs/            # 测试规范目录
├── .browserslistrc           # 浏览器兼容性配置
├── .eslintrc.js              # ESLint配置
├── .gitignore                # Git忽略文件配置
├── package.json              # 项目配置文件
├── README.md                 # 项目说明文件
├── vue.config.js             # Vue CLI配置文件
└── yarn.lock                 # yarn锁定文件
相关推荐
代码的余温7 分钟前
CSS3文本阴影特效全攻略
前端·css·css3
AlenLi16 分钟前
JavaScript - 策略模式在开发中的应用
前端
xptwop19 分钟前
05-ES6
前端·javascript·es6
每天开心19 分钟前
告别样式冲突:CSS 模块化实战
前端·css·代码规范
wxjlkh22 分钟前
powershell 批量测试ip 端口 脚本
java·服务器·前端
海底火旺23 分钟前
单页应用路由:从 Hash 到懒加载
前端·react.js·性能优化
每天开心23 分钟前
噜噜旅游App(3)——打造个性化用户中心:AI生成头像与交互设计
前端·前端框架
Heo24 分钟前
调用通义千问大模型实现流式对话
前端·javascript·后端
绅士玖25 分钟前
移动端自适应方案:lib-flexible + postcss-pxtorem 实践指南
前端
中微子29 分钟前
React + Vant 入门指南:轻松构建移动端应用
前端