public static function register(KaTeX parse error: Expected '}', got 'EOF' at end of input: …oload_register(autoload ?: ‘think\Loader::autoload’, true, true);
// 注册命名空间定义
self::addNamespace([
‘think’ => LIB_PATH . ‘think’ . DS,
‘behavior’ => LIB_PATH . ‘behavior’ . DS,
‘traits’ => LIB_PATH . ‘traits’ . DS,
]);
// 加载类库映射文件
if (is_file(RUNTIME_PATH . ‘classmap’ . EXT)) {
self::addClassMap(__include_file(RUNTIME_PATH . ‘classmap’ . EXT));
}
// Composer自动加载支持
if (is_dir(VENDOR_PATH . 'composer')) {
self::registerComposerLoader();
}
// 自动加载extend目录
self::$fallbackDirsPsr4[] = rtrim(EXTEND_PATH, DS);
}
解释:
1. 默认$autoload为空,使用PHP内置函数spl_autoload_register注册Loader类的静态方法autoload()方法为自动加载机制。
其意思即是,当使用类的时候,找不到类或者还没有包含,会将类名传给autoload()方法,让它处理。
2. 注册命名空间定义,是将命名空间与真实的文件路径对应一一对应,并且存储在一个类静态变量数组里面。
3. 以下的基本是一样的加载,只不过不是加载框架自身的类文件,而是加载composer库或者自己写的类。
总结一下,index.php加载start.php,在start.php里面加载base.php(类自动加载机制就在这里出现了),然后下面调用App的静态方法run方法执行“模块/控制器/操作”,返回Respose类的实例执行send方法,将响应数据发送给客户端,这样,一个完整的请求就完成了。
总结一下,index.php加载start.php,在start.php里面加载base.php(类自动加载机制就在这里出现了),然后下面调用App的静态方法run方法执行“模块/控制器/操作”,返回Respose类的实例执行send方法,将响应数据发送给客户端,这样,一个完整的请求就完成了。