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文件夹里面不要写命名空间

 PSR-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 类。

转载自:https://www.cnblogs.com/keiweila/p/7989432.html

发表评论

电子邮件地址不会被公开。 必填项已用*标注