the previously submitted note is incorrect.
A::foo();
is identical to
::A::foo();
in the global namespace.
The only way to successfully call the static method is to instantiate A and call it like:
<?php
$a = new A;
$a->foo();
?>
or to use reflection. This limitation is addressed in patches I have proposed, so the implementation may yet be usable in this regard.
Les espaces de noms
Sommaire
- Définition de l'espace de noms
- Utilisation des espaces de noms
- Espace global
- __NAMESPACE__
- Règles de résolution de noms
Les espaces de noms
Les espaces de noms, en PHP, ont été conçus pour résoudre un problème de portée de variables dans de grosses bibliothèques PHP. En PHP, toutes les définitions de classes sont globales. Ainsi, lorsqu'une bibliothèque crée divers utilitaires ou API de classes publiques, l'auteur doit être prudent sur le faire que d'autres bibliothèques avec les mêmes fonctionnalités peuvent exister et ainsi, choisir des noms uniques afin que les bibliothèques puissent être utilisées ensemble. Habituellement, l'on préfixe les noms des classes avec une chaîne unique, i.e. les classes des bases de données sont préfixées par Ma_Bibliotheque_DB, etc. Lorsque la bibliothèque grossit, les préfixes s'enchaînent et l'on atteint des noms très longs.
Les espaces de noms permettent aux développeurs de gérer les noms sans pour autant avoir des noms longs à chaque fois que la classe y réfère, et résout ainsi le partage des globales partagés sans rendre le code illisible.
Les espaces de noms sont disponibles en PHP depuis la version 5.3.0. Cette section est expérimentale et est susceptible de changer.
Les espaces de noms
22-Sep-2008 04:32
01-Sep-2008 02:01
In response to Amir Abiri's comment:
In this example:
<?php
//---
// global.php
class A {
public static function foo() {
echo "static function";
}
}
//----
// namespace.php
namespace A;
function foo() {
echo "namespace function";
}
?>
The way to call each of these functions is like so:
<?php
A::foo(); // "namespace function"
::A::foo(); // "static function"
?>
This could get pretty confusing, but at least now you know. :)
01-Aug-2008 11:02
This is my 'ultimate' autoload functie:
<?php
function __autoload($class) {
require('../includes/classes/' . str_replace('::', '/', strtolower($class)) . '.php');
}
//When you do:
$object = new PDF::Document();
?>
it will include the file:
../includes/classes/pdf/document.php
as you will notice I like to keep my includes outside the webroot.
document.php
<?php
namespace PDF;
class Document {
//etc...
}
?>
16-Jul-2008 05:31
you can use __autoload to automaticly include Classes with a "use" / "new" statement.
01-Jul-2008 09:19
So do you mean if i want to use a class, i need to do extra two steps?
1) require/include that file
2) use the namespace
What about to add a trigger something like:
function __auto_namespace($names, $class)
{
if ($class === null)
{
set_include_dir(implode('/', $names));
}
else
{
require_once implode('/', $names).'/'.$class.'.php';
}
}
Then when we:
use NAMESPACE1::NAMESPACE2;
or
use NAMESPACE1::NAMESPACE2::CLASS1;
php could auto include the file we needed.
26-Dec-2007 01:31
So, if I understand correctly there is a possible ambiguity that can cause a function or method to become "masked".
If I have:
global.php:
<?php
class A
{
static public function foo()
{
}
}
A::foo(); // Will statically call method foo() of class ::A.
?>
If I now added the following to my project:
A.php:
<?php
namespace A;
function foo()
{
}
?>
The function call above would instead call this new function.
It shouldn't be a problem most of the time and specially if certain basic practices are followed (For example, don't name classes and namespaces the same name, and always keep different packages in their own separate namespaces), but it's something to keep in mind.
