thinkphp5开发规范
目录结构
./application
./index
./controller 控制层
./model 模型
./view
./admin 后台模块
command.php 控制台配置,命令行执行,读取该模块
common.php 项目的公共文件,通用函数,全局调用
config.php 应用的配置文件
database.php 数据库配置文件
router.php 路由配置文件,对URL进行美化
tags.php 应用行为配置文件,默认提供很多钩子,对框架进行扩展,达到无需修改框架源码,注册函数/行为——>改变执行流程
./extend 非composer的第三方库存放地址
./public 网站根目录
favicon.ico 网站标签页图标
index.php 整个网站入口文件
robots.txt 搜索引擎配置文件
router.php 快速启动配置文件,无Apache时,通过thinkPHP内置的work server读取该文件,启动框架。例:php -S localhost:8888 router.php
./static 静态资源存放处,例: css、js、image
./runtime 网站运行中缓存文件,日志、缓存、编译文件
./thinkphp 框架文件
base.php 定义一些常量
composer.json composer的配置文件
console.php 控制台入口文件
convention.php 框架的默认配置文件
helper.php 助手函数
./lang 语言包
./library 核心
./think 框架核心文件
./traits 类库扩展
LICENSE.txt 法律声明文件
logo.png tp的logo
phpunit.xml phpunit测试的配置文件
readme.md 说明文件
start.php 框架启动文件
./tpl 框架默认模板文件
default_index.tpl 控制器模板
dispatch_jump.tpl 网站发出成功/失败的跳转模板
page_trace.tpl 调试时显示的
think_exception.tpl 抛出异常时页面展示的
./vendor composer安装存放区
开发规范
- 目录全部小写,下划线分割 例:./application
- 类库函数名均已.php结尾 例:./application/index/controller 下的 Index.php
- 类的文件名均已命名空间定义,且命名空间和类库文件所在的路径一致 例:./application/index/controller—— namespace app\index\controller; app定义顶级目录
- 类文件采用驼峰 首字母大写 其余文件小写+下划线命名
- 类名与类文件名保持一致,采用驼峰命名&首字母大写
- 类采用驼峰命名,首字母大写不需要添加后缀 Index √,IndexController ✘
- 函数名,驼峰,首字母小写 例:public function getUserName(){}
- 属性名,规则同7
- 以双下划线__开头的函数或方法为魔术方法
- 常量和配置 所以的常量都以大写字母+下划线命名 例: define(‘APP_STATE_’,‘dev’);
- 配置参数以小写字母+下划线命名
- 其他规范 数据库 表和字段名采用小写+下划线命名,不能以下划线开头 user_name
- 应用类库名统一使用"app"