Appearance
目录结构
Server 端
bash
Server 端
使用 Thinkphp8 多应用推荐目录结构
├─app(应用目录)
│ ├─admin
│ ├─api
│ └─common
│
├─config(配置目录)
│
├─database(数据库迁移文件-Phinx)
│
├─extend(扩展目录)
│
├─install(安装器源代码,此目录不一定存在)
│
├─public(运行目录)
│ ├─npm-install-test(npm install 测试项目)
│ ├─static
│ │ ├─fonts(一些字体)
│ │ │
│ │ └─images(一些图片)
│ │
│ └─storage(上传的文件保存在这里)
│
├─runtime(运行时目录,缓存、日志等)
│
├─web(WEB端源代码,见下文详叙)
│ .env-example(env 配置示例)
│ .gitattributes
│ .gitignore
│ .travis.yml
│ CHANGELOG.md(更新日志)
│ composer.json
│ README.md
└─ think(命令行入口文件)
更多细节,您还可以参考 TP文档中的目录结构,请翻阅多应用模式。
Web 端
bash
web 端
使用经典目录结构设计,并合理优化
├─public(公共文件)
├─src
│ │ App.vue
│ │ main.ts
│ │
│ ├─api(所有接口相关)
│ │ │ common.ts(公共 Url 定义和公共请求方法)
│ │ │
│ │ ├─backend(后台接口方法定义)
│ │ │
│ │ └─frontend(前台接口方法定义)
│ │
│ ├─assets(静态资源)
│ │
│ ├─components(组件)
│ │ ├─baInput(输入组件封装:常用+图片/文件上传、数组、城市/图标选择、富文本等封装在了一个组件内)
│ │ │
│ │ ├─contextmenu(tabs 右击菜单)
│ │ │
│ │ ├─formItem(表单项,结合 baInput)
│ │ │
│ │ ├─icon(字体图标组件,支持加载本地 svg、阿里、element、awesome)
│ │ │
│ │ ├─table(表格封装)
│ │ │
│ │ ├─mixins(可供模块混入代码到系统的埋点,如云存储,编辑器)
│ │ │
│ │ ├─clickCaptcha 点选文字验证码
│ │ │
│ │ └─terminal(终端)
│ │
│ ├─lang(所有语言包)
│ │ │ autoload.ts(语言包按需加载映射表,比如路由 /user/user 需要同时加载 /user/group 的语言包可在此定义)
│ │ │ globs-en.ts(全局英文语言包)
│ │ │ globs-zh-cn.ts(全局中文语言包)
│ │ ├─common(公共页面语言包:`t('dirName.pageName.翻译名')`进行调用)
│ │ ├─backend(后台页面语言包:`t('dirName.pageName.翻译名')`进行调用)
│ │ │ zh-cn.ts(后台公共中文语言包)
│ │ │ en.ts(后台公共英文语言包)
│ │ ├─frontend(前台页面语言包:`t('dirName.pageName.翻译名')`进行调用)
│ │ │ zh-cn.ts(前台公共中文语言包)
│ │ └─ en.ts(前台公共英文语言包)
│ │
│ ├─layouts(布局)
│ │ ├─backend(后台布局)
│ │ │ components (布局组件)
│ │ │ container (布局容器组件,内含默认的三种布局方案)
│ │ │ index.vue (后台布局入口)
│ │ ├─frontend(前台布局)
│ │ │ components (布局组件)
│ │ │ container (布局容器组件,内含默认的布局方案)
│ │ │ user.vue (会员中心布局入口)
│ │ └─common(公共布局组件)
│ │
│ ├─router(路由)
│ │ static.ts(静态路由配置)
│ │
│ ├─stores(状态商店)
│ │ ├─adminInfo.ts(管理员资料)
│ │ ├─config.ts(布局相关)
│ │ ├─memberCenter.ts(会员中心)
│ │ ├─navTabs.ts(后台顶栏 tab)
│ │ ├─siteConfig.ts(站点配置)
│ │ ├─terminal.ts(终端)
│ │ ├─userInfo.ts(用户资料)
│ │ ├─refs.ts(全局提供:引用(指向)一些对象(组件)的句柄)
│ │ │
│ │ ├─constant(常量定义)
│ │ │ cacheKey.ts(缓存 Key)
│ │ │
│ │ └─interface(接口定义)
│ │ index.ts
│ │
│ ├─styles(样式表)
│ │ app.scss
│ │ index.scss(css 入口文件,main.ts 只导入它就可以了)
│ │ element.scss(element 的 css 覆盖)
│ │ loading.scss
│ │ var.scss(css 变量定义)
│ │ dark.scss(暗黑模式下 css 变量定义)
│ │ mixins.scss(scss mixins 与 function 定义)
│ │
│ ├─utils(工具库)
│ │ axios.ts(网络请求封装)
│ │ baTable.ts(表格封装)
│ │ build.ts(构建时)
│ │ common.ts(公共方法)
│ │ directives.ts(指令)
│ │ horizontalScroll.ts(横向滚动工具)
│ │ iconfont.ts(图标)
│ │ layout.ts(布局辅助)
│ │ loading.ts(页面加载)
│ │ pageBubble.ts(页面气泡效果)
│ │ pageShade.ts(全局阴影)
│ │ random.ts(随机数、字符串生成)
│ │ router.ts(路由辅助)
│ │ storage.ts(local 缓存、session 缓存封装)
│ │ useCurrentInstance.ts(快速获取当前实例)
| | useDark.ts (暗黑模式相关工具函数)
│ │ validate.ts(一些表单验证方法)
│ │ vite.ts(vite运行与编译时)
│ │
│ └─views(视图)
│ ├─backend(后台视图)
│ ├─common(公共视图)
│ └─frontend(前台视图)
│
├─types
│ .editorconfig(IDE 风格统一配置)
│ .env(基础环境变量定义)
│ .env.development(开发环境变量定义)
│ .env.production(生产环境变量定义)
│ .prettierrc.js(prettier 配置)
│ eslint.config.js(eslint 配置)
│ index.html(入口文件)
│ package.json
│ README.md
│ tsconfig.json(ts 配置)
└─ vite.config.ts(vite 配置)