大多数情况下,PHP程序员都是只需使用include或require的基本功能,即在一个php脚本里include(require)另外一个php脚本,但往往容易忽略在一些情况下include(require)的作用域问题,并造成一些难以发觉的错误。该文就是想理清这样一个问题:在一个函数里使用include(require)时、被包含进来的变量、函数和类的作用域问题。
注意:本文档基于include叙述,但也适用于 require。这两种结构除了在如何处理包含失败之外,其他完全一样:在包含失败时,include()产生一个警告并继续执行,而require()则导致一个致命错误。换句话说,如果想在遇到丢失文件时停止处理页面就用require(),否则就用include()。
1、变量的作用域
vars.php
1 2 3 4 5 6 | <?php $color = 'green'; $fruit = 'apple'; ?> |
test.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | <?php function foo() { global $color; include 'vars.php'; echo "A $color $fruit"; } foo(); // A green apple echo "A $color $fruit"; // A green ?> |
由此例可看出:
(1) 被包含文件的变量的作用域遵从包含文件所在处的作用域。即在函数里使用include将其他文件的变量包含进来,这些变量的作用域为该函数内。
(2) foo()函数外能打印出$color的值,并没有违反(1)的规定。那是因为函数开始已经声明$color为global (尽管foo()函数外并没有$color变量,此时的$color变量并不是vars.php里面的$color变量,而是一个强制声明为“全局”的新变量,这时它还没有被赋值,当下面包含进vars.php后,根据(1)的原则,vars.php中的$color变量自动享有函数内的作用域,所以它的值就是全局变量$color的值)
2、函数、类的作用域
classb.php:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | <?php class ClassB { /** * constructor */ public function __construct(){} /** * destructor */ public function __destruct() {} public function printit() { echo 'print it in ClassB.<br />'; } } function show_func_included() { echo 'show_func_included<br/>'; } ?> |
classa.php:
1 2 3 4 5 6 7 8 9 10 | <?php function include_class() { include('classb.php'); } include_class(); $objB = new ClassB(); $objB->printit(); // print it in ClassB. show_func_included() // show_func_included ?> |
由此例可以看出:
所有在被包含文件中定义的函数和类在被包含后,在包含文件里都具有全局作用域
结论:
1、被包含文件的变量的作用域遵从(不改变)包含文件所在处的作用域。
2、所有在被包含文件中定义的函数和类在被包含后,在包含文件里都具有全局作用域
Good~
I want to find good pop music. Help me please.