这些我都看过,
我可以改变,但在我的 MV* 结构中我有:
/models
customer.class.php
order.class.php
/controllers
customer.controller.php
order.controller.php
/views
...
Run Code Online (Sandbox Code Playgroud)
在他们实际的课堂上,
class CustomerController {}
class OrderController{}
class CustomerModel{}
class OrderModel{}
Run Code Online (Sandbox Code Playgroud)
我试图与名称保持一致。如果我不添加类名后缀(控制器、模型),我将无法加载该类,因为这是重新声明。
如果我保留类的名称,自动加载会失败,因为它将查找名为的类文件
CustomerController
Run Code Online (Sandbox Code Playgroud)
当文件名确实是,
customer.controller.php
Run Code Online (Sandbox Code Playgroud)
我唯一的方法是(排名不分先后):
include、
require_once等)?
示例代码,
function model_autoloader($class) {
include MODEL_PATH . $class . '.model.php';
}
spl_autoload_register('model_autoloader');
Run Code Online (Sandbox Code Playgroud)
看来我必须重命名文件,
http://www.php-fig.org/psr/psr-4/
“终止类名对应于以 .php 结尾的文件名。文件名必须与终止类名的大小写匹配。”
在我看来,这可以通过一些基本的字符串操作和一些约定来处理。
define('CLASS_PATH_ROOT', '/');
function splitCamelCase($str) {
return preg_split('/(?<=\\w)(?=[A-Z])/', $str);
}
function makeFileName($segments) {
if(count($segments) === 1) { // a "model"
return CLASS_PATH_ROOT . 'models/' . strtolower($segments[0]) . '.php';
}
// else get type/folder name from last segment
$type = strtolower(array_pop($segments));
if($type === 'controller') {
$folderName = 'controllers';
}
else {
$folderName = $type;
}
$fileName = strtolower(join($segments, '.'));
return CLASS_PATH_ROOT . $folderName . '/' . $fileName . '.' . $type . '.php';
}
$classNames = array('Customer', 'CustomerController');
foreach($classNames as $className) {
$parts = splitCamelCase($className);
$fileName = makeFileName($parts);
echo $className . ' -> '. $fileName . PHP_EOL;
}
Run Code Online (Sandbox Code Playgroud)
输出是
客户 -> /models/customer.php
CustomerController -> /controllers/customer.controller.php
makeFileName您现在需要在自动加载器函数内部使用。
我本人是强烈反对这样的事情的。我将使用反映命名空间和类名的命名空间和文件名。我也会使用Composer。
(我splitCamelCase 在这里找到的。)