0

我正在尝试对可变变量做一些事情,但我遇到了一个对象问题。想象一下这个类设置:

class A
{
  public $field = 10;
}

class B
{
  public $a;

  public function __construct()
  {
    $this->a = new A();
  }
}

现在每个人都知道这段代码有效:

$a = new A();
$var = 'field';
echo $a->$var; // this will echo 10

有没有可能我可以做这样的事情?:

$b = new B();
$var = 'a->field';
echo $b->$var; // this fails

注意:任何不使用 eval 功能的选项?

4

4 回答 4

2

使用闭包怎么样?

$getAField = function($b) {
    return $b->a->field;
};

$b = new B();
echo $getAField($b);

不过,它只能在较新版本的 PHP 中实现。

或者,作为更通用的版本,如下所示:

function getInnerField($b, $path) { // $path is an array representing chain of member names
    foreach($path as $v)
        $b = $b->$v;
    return $b;
}

$b = new B();
echo getInnerField($b, array("a", "field"));
于 2012-04-18T19:15:10.130 回答
1

你可以在你的类上编写一个自定义的 __get 方法来访问 childrens 属性。这有效:

class A
{
  public $field = 10;
}

class B
{
  public $a;

  public function __construct()
  {
    $this->a = new A();
  }

  public function __get($property) {
    $scope = $this;

    foreach (explode('->', $property) as $child) {
      if (isset($scope->$child)) {
    $scope = $scope->$child;
      } else {
    throw new Exception('Property ' . $property . ' is not a property of this object');
      }
    }

    return $scope;
  }
}

$b = new B();
$var = 'a->field';
echo $b->$var;

希望有帮助

于 2012-04-18T19:25:22.653 回答
0

我不推荐它,但你可以使用 eval:

$b = new B();
$var = 'a->field';
eval( 'echo $b->$'.$var );
于 2012-04-18T19:13:45.933 回答
0

我猜这也应该有效:

$b = new B();
$var1 = 'a'; 
$var2 = 'field'

echo ($b->$var1)->$var2; 
于 2012-04-18T19:23:07.300 回答