composer.json 文件理解及使用composer dump-autoload
composer.json
1依赖管理
require
5.3.*表示,可以使用5.3.1版本,也可以使用5.3.2版本,
"require": {
"php": ">=5.6.4",
"erusev/parsedown": "^1.6",
"laravel/framework": "5.4.*",
"laravel/tinker": "~1.0",
"mockery/mockery": "0.9.*",
"swiftmailer/swiftmailer": 5.3.*@dev,@dev表示可以获取开发版本。通常,开发版本意味非稳定版本,很可能存在bug。稳定性标签可以作用于特定的依赖项,也可以作用于全局。
},
全局稳定性设置:通过设置minimum-stability的值,来告诉Composer当前开发的项目的依赖要求的包的全局稳定性级别,它的值包括:dev、alpha、beta、RC、stable,stable是默认值。
2自动加载 //再此运行composer dump-autoload,尝试调用
"files": [
"app/Helper/function.php"
]
"autoload":{
"files":["aa/bb.php”],////不需要命名空间
}
//files键对应的值是一个数组,数组元素是文件的路径,路径是相对于应用的根目录。加上上述内容后,运行命令:
Classmap方式自动加载
通过文件引入的方法虽然直观,但是很费劲,每个文件都得引入一次,实在不是好的解决办法。有没有更好的办法呢?尝试将autoload的值改成:
"classmap": [
"database",
"aa"
],
aa文件夹里面不要写命名空间
3
PSR0/4加载方式
FIG组织制定的一组PHP相关规范,简称PSR,其中
PSR-0自动加载
PSR-1基本代码规范
PSR-2代码样式
PSR-3日志接口
PSR-4 自动加载
"psr-4": {
"App\\": "app/", //前面是命名空间,后面是目录结构
"Models\\": "models/",
"Persimmon\\": "app/Persimmon"
},
{
"autoload": {
"psr-4": {"Acme\\": "src/"}
}
}
Composer 将注册一个 PSR-4 autoloader 到 Acme 命名空间。
你可以定义一个从命名空间到目录的映射。此时 src 会在你项目的根目录,与 vendor 文件夹同级。例如 src/Foo.php 文件应该包含 Acme\Foo 类。