Modern-php 书摘(一)namespace

396 查看

命名空间

命名空间的声明

  • 命名空间在PHP文件的顶部,<?php 标签后的第一行声明;

  • 命名空间声明语句以namespace开头,随后是一个空格,然后是命名空间的名称,最后以;结尾;

  • 厂商命名空间即下面声明的“Oreilly”是最重要的命名空间;必须具有全局唯一性。

<?php
namespace Oreilly;

子命名空间

<?php
namespace Oreilly\ModernPHP;

Ps: 同一个命名空间下的所有类、接口、函数没必要在同一个PHP文件中声明;
所以,我们可以在不同的文件中编写属于同一个命名空间的多个类。

import and alias

PHP引入namespace之前,开发者们使用Zend式的类名来解决命名冲突问题;

# Zend_Cloud_DocumentService_Adapter_WindowsAzure_Query => Zend/Cloud/DocumentService/Adapter/WindowsAzure/Query.php

但是你也看到了,太TM长了,不能忍啊!!!
namespace提供了 import和 alias来解决这个问题。
import,alias 在5.3版本下支持类,接口与命名空间导入。5.6开始支持函数与常量导入。

# namespace without alias
<?php
$response = new \Symfony\Component\HttpFoundation\Response('Oops',400);
$response->send();
$response2 = new \Symfony\Component\HttpFoundation\Response('Success',200);
# namespace with Default alias 
use Symfony\Component\HttpFoundation\Response;
$response = new Response('Oops',400);
$response->send();
# namespace with custom alias 
use Symfony\Component\HttpFoundation\Response as Res;
$response = new Res('Oops',400);
$response->send();

注意:

  • 同namespace声明一样,在PHP文件顶部使用use关键字,而且在<?php 标签或者声明命名空间之后;

  • 开头无需加\符号,因为PHP导入是完全限定;

  • use必须出现在全局作用域中,因为use在编译时使用。

PHP5.6以后可以导入函数和常量;

<?php
use func Namespace\functionName;

functionName();

导入常量:

<?php
use constant Namespace\CONST_NAME;

echo CONST_NAME;

实用技巧

多重导入

如果想在一个PHP文件中导入多个类、接口、函数或者常量,需要使用多个use语句;

不建议:

<?php
use Symfony\Component\HttpFoundation\Request,
    Symfony\Component\HttpFoundation\Response,
    Symfony\Component\HttpFoundation\Cookie;

建议:

<?php
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\HttpFoundation\Cookie;

PHP允许一个文件定义多个命名空间【强烈不建议】

<?php
namespace Foo {
    //...
}

namespace Bar {
    //...
}

全局命名空间

<?php
namespace My\App;

class Foo
{
    public function doSomething()
    {
        $ex = new \Exception();
    }
}

NOTE: 此时,在 Exception类的名称前加\前缀是告诉PHP在全局中查找Exception,默认会在当前命名空间中查找;