本文目录一览:
- 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 它包含了四个文件的全部映射,是为了精简篇幅这里不做介绍了