这也是OO设计的基本思想之一。在PHP5之前,如果需要使用一个类,只需要直接使用include/require将其包含进来即可。下面是一个实际的例子: <div class="codetitle"><a style="CURSOR: pointer" data="74731" class="copybut" id="copybut74731" onclick="doCopy('code74731')"> 代码如下:<div class="codebody" id="code74731"> class ClassA{ public function construct(){ echo “ClassA load success!”; } } //定义一个类ClassA,文件名为ClassA.php class ClassA{ public function construct(){ echo “ClassA load success!”; } } class ClassB extends ClassA { public function construct(){ //parent::construct(); echo “ClassB load success!”; } } //定义一个类ClassB,文件名为ClassB.php,ClassB继承ClassA class ClassB extends ClassA { public function construct(){ //parent::construct(); echo “ClassB load success!”; } } 定义两个测试用的类之后,我们来编写一个含有autoload()方法的PHP运行程序文件如下: function autoload($classname){ $classpath=”./”.$classname.'.php'; if(file_exists($classpath)){ require_once($classpath); } else{ echo ‘class file'.$classpath.'not found!'; } } $newobj = new ClassA(); $newobj = new ClassB(); 这个文件的运行是一点问题都没有的,可见autoload是多么的好用啊,呵呵…… 但是不得不提醒你一下几个方面是必须要注意的。 1、如果类存在继承关系(例如:ClassB extends ClassA),并且ClassA不在ClassB所在目录 利用autoload魔术函数实例化ClassB的时候就会受到一个致命错误: Fatal error: Class ‘Classd' not found in ……ClassB.php on line 2, 解决方法:把所有存在extends关系的类放在同一个文件目录下,或者在实例化一个继承类的时候在文件中手工包含被继承的类; 2、另外一个需要注意的是,类名和类的文件名必须一致,才能更方便的使用魔术函数autoload; 其他需要注意的事情: 3、在CLI模式下运行PHP脚本的话这个方法无效; 4、如果你的类名称和用户的输入有关——或者依赖于用户的输入,一定要注意检查输入的文件名,例如:.././这样的文件名是非常危险的。 (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|