本文目錄一覽:
- 1、PHP中如何用autoload($class) 實現Lib目錄下的類的自動載入並可以兼容子目錄?
- 2、請問怎樣用js,php等網頁技術實現頁面自動載入。
- 3、詳解PHP文件的自動載入(autoloading)
- 4、Composer 自動載入原理
PHP中如何用autoload($class) 實現Lib目錄下的類的自動載入並可以兼容子目錄?
php自動載方法有兩種.
第一種方案用__autoload,這個函數較簡單,也較弱.
但有一問題沒有解決, 就是在include前判斷文件是否存在的問題.
set_include_path(‘aa’ . PATH_SEPARATOR . get_include_path());
function __autoload($className)
{
//如果加這個檢測, 因為此文件不在當前目錄下,它就會檢測不到文件存在,
//但include是能成功的
if (file_exists($className . ‘.php’)) {
include_once($className . ‘.php’);
} else {
exit(‘no file’);
}
}
$a = new Acls();
第二種方案用spl自動載入,這裡具體說一下這個.
spl_autoload_register()
一個簡單的例子
set_include_path(‘aa’ . PATH_SEPARATOR . get_include_path());
//function __autoload($className)
//{
// if (file_exists($className . ‘.php’)) {
// include_once($className . ‘.php’);
// } else {
// exit(‘no file’);
// }
//}
spl_autoload_register();
$a = new Acls();
請問怎樣用js,php等網頁技術實現頁面自動載入。
監聽window.onscroll事件,當滾動條位置變化的時候,檢查是否已經到達底部,如果是,則使用AJAX載入下一頁的內容,並添加到列表後面。
代碼大概是這樣:
// 監聽滾動條變化的事件
window.onscroll = function() {
var body = document.body;
// 檢查滾動條是否已達到底部
if(body.scrollTop + body.clientHeight == body.scrollHeight) {
// 如果達到底部,則使用AJAX請求下一頁數據
$.ajax({
url: ”,
success: function() {
// 請求完成,將數據添加到列表底部
}
});
}
}
詳解PHP文件的自動載入(autoloading)
傳統上,在PHP里,當我們要用到一個class文件的時候,我們都得在文檔頭部require或者include一下:
?php
require_once(‘../includes/functions.php’);
require_once(‘../includes/database.php’);
require_once(‘../includes/user.php’);
…
但是一旦要調用的文檔多了,就得每次都寫一行,瞅著也不美觀,有什麼辦法能讓PHP文檔自動載入呢?
?php
function
__autoload($class_name)
{
require
“./{$class_name}.php”;
}
對,可以使用PHP的魔法函數__autoload(),上面的示例就是自動載入當前目錄下的PHP文件。當然,實際當中,我們更可能會這麼來使用:
?php
function
__autoload($class_name)
{
$name
=
strtolower($class_name);
$path
=
“../includes/{$name}.php”;
if(file_exists($path)){
require_once($path);
}else{
die(“the
file
{$class_name}
could
not
be
found”);
}
}
也即是做了一定的文件名大小寫處理,然後在require之前檢查文件是否存在,不存在的話顯示自定義的信息。
類似用法經常在私人項目,或者說是單一項目的框架中見到,為什麼呢?因為你只能定義一個__autoload
function,在多人開發中,做不到不同的developer使用不同的自定義的autoloader,除非大家都提前說好了,都使用一個__autoload,涉及到改動了就進行版本同步,這很麻煩。
也主要是因為此,有個好消息,就是這個__autoload函數馬上要在7.2版本的PHP中棄用了。
Warning
This
feature
has
been
DEPRECATED
as
of
PHP
7.2.0.
Relying
on
this
feature
is
highly
discouraged.
那麼取而代之的是一個叫spl_autoload_register()的東東,它的好處是可以自定義多個autoloader.
//使用匿名函數來autoload
spl_autoload_register(function($class_name){
require_once(‘…’);
});
//使用一個全局函數
function
Custom()
{
require_once(‘…’);
}
spl_autoload_register(‘Custom’);
//使用一個class當中的static方法
class
MyCustomAutoloader
{
static
public
function
myLoader($class_name)
{
require_once(‘…’);
}
}
//傳array進來,第一個是class名,第二個是方法名
spl_autoload_register([‘MyCustomAutoloader’,’myLoader’]);
//甚至也可以用在實例化的object上
class
MyCustomAutoloader
{
public
function
myLoader($class_name)
{
}
}
$object
=
new
MyCustomAutoloader;
spl_autoload_register([$object,’myLoader’]);
值得一提的是,使用autoload,無論是__autoload(),還是spl_autoload_register(),相比於require或include,好處就是autoload機制是lazy
loading,也即是並不是你一運行就給你調用所有的那些文件,而是只有你用到了哪個,比如說new了哪個文件以後,才會通過autoload機制去載入相應文件。
當然,laravel包括各個package里也是經常用到spl_autoload_register,比如這裡:
/**
*
Prepend
the
load
method
to
the
auto-loader
stack.
*
*
@return
void
*/
protected
function
prependToLoaderStack()
{
spl_autoload_register([$this,
‘load’],
true,
true);
}
Composer 自動載入原理
到達 composer 工作區
實現自動載入的過程可簡單分為三步:
下面演示 laravel 四種聲明載入標準的組件,是如何歸納的。
文件預載入,框架啟動時便被 include ,通常文件中提供一些函數方法方便我們使用,如經常用的 dd() 。
“files:[“src/Illuminate/Foundation/helpers.php”]” 寫入 /composer/autoload_files.php ,
直接映射文件真實路徑。 這是簡單粗暴的,因此這種方式效率是最高的。
“classmap”: [“hamcrest”] , 寫入 /composer/autoload_classmap.php
當 use Hamcrest\\Arrays\\IsArray; 時,可直接在 classmap 的數組中找到它,是不是很粗暴呢。
這是最常用的載入標準。 “psr-4”: {“App\\”: “app/”} 寫入 autoload_psr4.php
只要是 app/ 目錄下的文件,且名命空間符合 psr-4 標準的類文件都能被自動載入。如 use App\Test = app/Test.php 。而 classmap 方式不可以,這樣你可以在 app/ 下自由的增加 / 刪除類文件了。
這裡提一下,前面說 classmap 方式是最高效的,而 composer dump-autoload 可以將通過 psr-4 規範載入的文件 「落盤」,即寫入 autoload_classmap.php 。從而起到加速的作用,官方建議生產環境時執行 composer dump-autoload –optimize 來優化項目的自動載入速度。
為了說明 composer dump-autoload 的作用,我在 app 目錄下建立 Test.php
執行 composer dump-autoload 後,發現在 autoload_classmap.php 與 autoload_static.php (稍後再提及)中找到了它。
而 composer dump-autoload –optimize 的作用是進行優化(optimize),清理無效索引空間另外在 /composer 生成了 user 緩存文件。
和 psr-4 類似,只是載入規則有所不同。官方已棄用,但 laravel 有的組建包還是在用的,composer 仍然支持向下兼容。 “psr-0”: {“Mockery”: “library/”} 寫入 autoload_namespaces.php 。
註: autoload_static.php 它包含了四個文件的全部映射,是為了精簡篇幅這裡不做介紹了
原創文章,作者:OEDUC,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/318068.html