我正在学习使用php autuoloader
...
据我了解,我们可以使用__autoloader
或spl_autoloader_*
自动加载文件。
假设这是我的目录结构:
ROOT
|
|
ADMIN
| |
| |
| DIST
| |
| SOME_FOLDER
| SOME_FOLDER
| TPL
| |
| |
| SOME_FOLDER1
| |
| test.php
| SOME_FOLDER2
| |
| example1.php
| example2.php
| example3.php
|
|
CLASSES
|
basics.php
class1.php
class2.php
class3.php
class4.php
|
index.php
我在CLASSES
目录basics.php中创建了此类用于自动加载文件的类
:
class MyAutoLoader
{
public function __construct()
{
spl_autoload_register( array($this, 'load') );
}
function load( $file )
{
//spl_autoload( 'load1' );
echo 'Try to call ' . $file . '.php inside ' . __METHOD__ . '<br>';
require( $file . '.php' );
}
}
并且index.php
我将包括basics.php
,一切都很好,因为文件存储在CLASSES
文件夹中...
require_once("CLASSES/basics.php");
$loaderObject = new MyAutoLoader();
使用此代码,我可以声明class1
...
class3
现在我想拥有一个可以装载文件的autoloder,SOME_FOLDER2
在这种情况下是example1.php
,example2.php
并且example3.php
在某些情况下我尝试过,但是SOME_FOLDER2
不会使用autoloader装载文件。
我的尝试:
我做了一个load2
在MyAutoLoader
类中命名的函数,试图包含来自SOME_FOLDER2
function load2( $file )
{
//spl_autoload_register('load2');
echo 'Inside LOADER2 ' . __METHOD__ . '<br>';
require ( 'ADMIN/TPL/' . $file . '.php' );
}
我改变spl_autoload_register
了MyAutoLoader
构造函数:
$allMethods = get_class_methods( 'MyAutoLoader' );
$allMethods = array_splice( $allMethods, 1 );
foreach( $allMethods as $method )
{
spl_autoload_register( array($this, $method) );
}
但是它们都不对我
有用...您能告诉我我的代码有什么问题还是我对自动加载器的误解是什么?
Thanks in Advance
我认为您的问题基本上可以归结为在查看文件之前不检查文件是否存在require
...如果您尝试包含的第一个文件夹中不存在该文件,则会产生致命错误。
我不知道您的用例,但是这里有一些建议:
您可以只使用一个自动装带器吗?
function my_autoload($class_name) {
if (is_file('CLASSES/' . $class_name . '.php')) {
require_once 'CLASSES/' . $class_name . '.php';
} else if (is_file('ADMIN/TPL/SOME_FOLDER2/' . $class_name . '.php')) {
require_once 'ADMIN/TPL/SOME_FOLDER2/' . $class_name . '.php';
}
}
spl_autoload_register("my_autoload");
或者,如果您需要独立声明它们(即两个或多个自动加载器):
function classes_autoload($class_name) {
if (is_file('CLASSES/' . $class_name . '.php')) {
require_once 'CLASSES/' . $class_name . '.php';
}
}
spl_autoload_register("classes_autoload");
function admin_autoload($class_name) {
if (is_file('ADMIN/TPL/SOME_FOLDER2/' . $class_name . '.php')) {
require_once 'ADMIN/TPL/SOME_FOLDER2/' . $class_name . '.php';
}
}
spl_autoload_register("admin_autoload");
或者使您的自动加载器类通用:
class MyAutoLoader {
private $path;
public function __construct($path) {
$this->path = $path;
spl_autoload_register( array($this, 'load') );
}
function load( $file ) {
if (is_file($this->path . '/' . $file . '.php')) {
require_once( $this->path . '/' . $file . '.php' );
}
}
}
$autoloader_classes = new MyAutoLoader('CLASSES');
$autoloader_admin = new MyAutoLoader('ADMIN/TPL/SOME_FOLDER2');
如果您不想手动保持ADMIN/TPL
最新的子文件夹列表,您甚至可以执行以下操作从其中的任何一个自动加载(显然,这假定ADMIN/TPL
包含类的所有子文件夹):
function my_autoload($class_name) {
if (is_file('CLASSES/' . $class_name . '.php')) {
require_once 'CLASSES/' . $class_name . '.php';
} else {
$matching_files = glob('ADMIN/TPL/*/' . $class_name . '.php');
if (count($matching_files) === 1) {
require_once $matching_files[0];
} else if (count($matching_files) === 0) {
trigger_error('Could not find class ' . $class_name . '!', E_USER_ERROR);
} else {
trigger_error('More than one possible match found for class ' . $class_name . '!', E_USER_ERROR);
}
}
}
spl_autoload_register("my_autoload");
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句