欢迎各位兄弟 发布技术文章

这里的技术是共享的

You are here

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

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

来自  https://blog.csdn.net/weixin_30394251/article/details/95134577


普通分类: