composer.json 文件理解及使用composer dump-autoload

composer.jsonphp

 

 

1依賴管理laravel

 

 requirejson

5.3.*表示,能夠使用5.3.1版本,也能夠使用5.3.2版本,swift

 

"require": {
    "php": ">=5.6.4",數組

"erusev/parsedown": "^1.6",
    "laravel/framework": "5.4.*",
 "laravel/tinker": "~1.0",
app

"mockery/mockery": "0.9.*",composer

"swiftmailer/swiftmailer": 5.3.*@dev,@dev表示能夠獲取開發版本。一般,開發版本意味非穩定版本,極可能存在bug。穩定性標籤能夠做用於特定的依賴項,也能夠做用於全局。
},
ui

全局穩定性設置:經過設置minimum-stability的值,來告訴Composer當前開發的項目的依賴要求的包的全局穩定性級別,它的值包括:dev、alpha、beta、RC、stable,stable是默認值。spa

 

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

相關文章
相關標籤/搜索