使用包含常量名称的简单变量访问类常量


Accessing a class constant using a simple variable which contains the name of the constant

我正试图访问我的一个类中的类常量:

const MY_CONST = "value";

如果我有一个变量,它包含这个常量的名称,如下所示:

$myVar = "MY_CONST";

我可以以某种方式访问MY_CONST的值吗?

self::$myVar

这显然不起作用,因为它是针对静态属性的。此外,变量也不起作用。

有两种方法可以做到这一点:使用常量函数或使用反射。

常数函数

常量函数与通过define声明的常量以及类常量一起工作:

class A
{
    const MY_CONST = 'myval';
    static function test()
    {
        $c = 'MY_CONST';
        return constant('self::'. $c);
    }
}
echo A::test(); // output: myval

反射类

第二种更费力的方法是通过反思:

$ref = new ReflectionClass('A');
$constName = 'MY_CONST';
echo $ref->getConstant($constName); // output: myval

没有语法,但可以使用显式查找:

print constant("classname::$myConst");

我相信它也适用于self::

我可以以某种方式访问MY_CONST的值吗?

self::MY_CONST

如果您想动态访问,您可以使用反射APIDocs:

$myvar = 'MY_CONST';
$class = new ReflectionClass(self);
$const = $class->getConstant($myVar);

反射API的好处可以是您可以一次获得所有常量(getConstants(。

如果你不喜欢反射API,因为你不想使用它,一个替代方案是constant函数(Demo(:

$myvar = 'MY_CONST';    
class foo {const MY_CONST = 'bar';}    
define('self', 'foo');    
echo constant(self.'::'.$myvar);

Reflection注意:ReflectionClass的构造函数必须为其参数接收类的完整路径。这意味着在某些情况下,仅将字符串"A"设置为构造函数参数可能不起作用。

为了避免这个问题,当使用ReflectionClass时,如果你这样做会更好:

$classA = new A();
$name_classA = get_class($classA);
$ref = new ReflectionClass(get_class($name_classA));
$constName = 'MY_CONST';
echo $ref->getConstant($constName);

只要您在代码中,函数get_class就会为您提供类的完整路径。缺少完整路径可能会导致"找不到类"PHP错误。

你试过吗

$myVar = MY_CONST or $myVar = $MY_CONST