<delect id="sj01t"></delect>
  1. <em id="sj01t"><label id="sj01t"></label></em>
  2. <div id="sj01t"></div>
    1. <em id="sj01t"></em>

            <div id="sj01t"></div>
            php語言

            PHP自動加載

            時間:2025-03-12 02:48:32 php語言 我要投稿
            • 相關推薦

            PHP自動加載

              很多的初學者在學習 PHP 的時候最早面對的問題之一就是 require 、 include 和 require_once 、include_once 的相愛相殺。那么在了解了它們相愛相殺的故事后,往往就開始使用起了框架。以下是關于框架的介紹,希望對大家有用,更多內容請關注應屆畢業生網!

              框架固然是干活的好工具,但是你知道你平時 new 一個新類的時候,發生了什么嗎?有想過為什么我們遵循規范就會自動的幫我們做好一切的加載嗎? 讓我們一切來探索發現其中的奧秘。

              時間線

              蒸汽時代

              在 PHP 代碼的頂部你是不是經常看到這樣的代碼。

              require 'lionis.php';require 'is.php';require 'cool.php';

              如果只是引入幾個 PHP 腳本,那還可以接受。那引入成千上萬個腳本的時候,爆炸是在所難免的。如果對一個腳本改了個名字,還需要對引入改腳本的每個腳本改名,能不爆炸嗎?連打出這段話都怎么繞。

              電氣時代

              在 PHP 電氣時代,開始出現了 __autoload 和 spl_autoload_register 函數注冊自定義的自動加載策略。

              通俗的來說,__autoload 和 spl_autoload_register 是一個 殺手組織,他們會去雇傭 各國殺手 (函數)。當我們想搞定某個人的時候(new),只需要提供名字(類名),剩下的 殺手 會幫我們搞定的。

              __autoload

              PHP 5 開始提供這個函數 傳送門。當你使用的 類 找不到的時候,它把類名當成參數扔進這個函數。

              }

              }

              }$lionis = new Lionis();

              輸出

              歐耶耶, 我就是 Lionis

              spl_autoload_register

              如果我們 項目 很大很老又或者你是一個 愛折騰 的少先隊員,需要引入的東西有不一樣的規范,這時候如果都放在 autoload 函數里,這個函數馬上就會膨脹的。而且autoload 是全局唯一的,如果被人占用了,可能會導致錯誤。(欲使一個人滅亡,必將先使其膨脹。)

              PHP 5.1.2 開始提供這個函數 傳送門,注冊給定的函數作為 __autoload 的實現。所以,我們看一些框架或插件在自己使用的時候,為了兼容可能會出現 function_exists(spl_autoload_register)。

              }// 函數spl_autoload_register('lionisIsCoolFind');// 匿名函數spl_autoload_register(function($require) { require './' . $classname . '.php';

              });// 類中的函數spl_autoload_register(array('Lionis', 'loadClass'));

              歐耶,這下我們可以寫很多不同的自動加載函數了。

              信息時代

              師傅小心,前面有妖氣! 。如果我們每個人都自己實現一套自動加載的方法,每個PHP 組件和 框架都使用獨特的自動加載器,而且每個框架使用不同的邏輯加載PHP類、接口和性狀。

              那當我們使用一些第三方框架的時候,還需要去弄清楚引導文件中的 自動加載器,那樣是有多和 時間 過不去呢。 PHP-FIG 認識到了這個問題了,推薦使用 PSR-4 規范,來促進組件之間的 互操作性,這樣我們就可以使用一個自動加載器了。

              PSR-4 規范

              利用命名空間的前綴和文件系統中的目錄對應起來。

              映射關系為

              namespace => filePath\Lionis\Cool => cool

              帶有命名空間的類

              }

              創建一個對象

              這個時候,按照 PSR-4 的規范,自動加載器應該去加載 cool/ 目錄下的 Real.php。

              不對!那這樣不是還要自己去實現 自動加載器 嘛,不然怎么 無中生有 出現 自動加載器 呢?難道官方 內置 了?

              你 out 了吧,我們可以使用依賴管理器 composer 來生成 PSR-4 自動加載器。你可能會疑問,那我的舊項目沒有遵循 PSR-4 規范怎么辦?嘿嘿,讓我們來探索發現一下 composer 是怎么解決這個問題的吧。

              Composer

              哦吼吼,我們這次的重點在與探究自動加載,所以 composer 的安裝和使用等,就不去討論了。

              composer 自動加載設置了 4種 加載方式:

              PSR-0

              PSR-4

              classmap

              files

              PSR-0

              要求命名空間和目錄層層對應,且可以使用 _ 作為路徑分隔符,但是這會導致目錄結果變得過深。

              在 composer 執行 install 等操作時,composer 會把文件中的配置存儲在 vendor/composer/autoload_psr0.php文件中的返回數組中。

              例如:定義了Very\Good=>vendor\Lionis\IsReal\Cool,在調用 use Very\Good\Love\SomeClass,PSR-0 加載的實際目錄為 vendor/Lionis/IsReal/Cool/Very/Good/Love/SomeClass.php。

              對吧,這簡直深得嚇人,所以 PSR-0 被官方廢除了。但是一些主流的框架已經實現了 PSR-0,為了向下兼容還是要實現 PSR-0。

              composer.json配置:"autoload": { "psr-0": { "Very\\Good": "vendor\Lionis\IsReal\Cool"

              }

              }

              PSR-4

              PSR-4 是現在比較推薦的方法,用于替代 PSR-0。

              與 PSR-0 不同的是,取消掉了 _ 作為分隔符和目錄結構。

              在 composer 執行 install 等操作時,composer 會把文件中的配置存儲在 vendor/composer/autoload_psr4.php文件中的返回數組中。

              例如:定義了Very\Good=>vendor\Lionis\IsReal\Cool,在調用 use Very\Good\

              Love\SomeClass,PSR-4 加載的實際目錄為 vendor/Lionis/IsReal/Cool/Love/SomeClass.php。

              composer.json配置:

              "autoload": { "psr-4": { "Very\\Good": "vendor\Lionis\IsReal\Cool"

              }

              }

              classmap

              classmap 通過配置指定的目錄和文件,在 composer 執行 install 等操作時,composer 會去掃描對應的目錄下以.php結尾的文件中的 class,并存儲在 vendor/composer/autoload_classmap.php文件中的返回數組中。

              composer.json配置:"autoload": { "classmap": [ "Lionis/", "Xiaoer/"

              ]

              }

              如果 Lionis 下有一個叫 VeryCool的文件,那么在vendor/composer/autoload_classmap.php 中會生成。

              $baseDir . '/Lionis/VeryCool.php', // 其他的映射);

              files

              files 就是直接簡單粗暴的加載文件。在 composer 執行 install 等操作時,composer 會把文件中的配置存儲在 vendor/composer/autoload_static.php文件中的生成一個 $files 數組。

              composer.json 配置:"autoload": { "files": ["Lionis/Very/Cool.php"]

              }

              小結

              composer 通過使用 composer.json,用 json 的格式來指定我們需要自動加載的規則。我們只要在入口文件引入 vendor/autoload.php 就能很方便的便能使用 自動加載。

              如果你對 composer 實現 自動加載 的原理感興趣,可以順著 vendor 中的 autoload.php 去看看源碼。

              總結

              從 石器時代 到 信息時代,PHP 經歷了很多試驗和改變后正在變得越來越好。當然,許多優秀的框架讓我們開發速度更快,需要理解的一些知識點也隨之被隱藏起來,讓我們更加專注于實現邏輯。但是,我們有的時候還是要嘗試的去理解他們工作的原理,來提升我們自己。像我老師說過的,所不定一下子踩到狗屎運了呢。

            【PHP自動加載】相關文章:

            php自動生成sitemap地圖代碼10-21

            使用php自動提交表單的方法11-16

            php自動生成sitemap地圖的代碼10-07

            php自動生成sitemap地圖的代碼07-31

            PHP自動獲取關鍵字的方法技巧08-11

            jquery+php實現搜索框自動提示07-16

            php+ajax實時輸入自動搜索匹配的方法10-08

            如何實現PHP靜態新聞列表自動生成代碼08-19

            php中tp驗證表單與自動填充函數代碼07-16

            <delect id="sj01t"></delect>
            1. <em id="sj01t"><label id="sj01t"></label></em>
            2. <div id="sj01t"></div>
              1. <em id="sj01t"></em>

                      <div id="sj01t"></div>
                      黄色视频在线观看