我遇到了一个问题,我不确定这是否只是正常行为,或者我写错了什么。我的基类中有一个方法,它通过为该特定类的所有新实例创建代理来将全局过滤器应用于给定类。我计划的方式如下:
- 附加
static $global_filter
(代理)到我要过滤的类,它扩展了基类object
- 通过我的加载机制,在新实例化时返回代理而不是实际类(这将屏蔽方法调用并相应地应用过滤器)
但是,我陷入了第 1 步,似乎当我尝试分配static $global_filter
给我想要过滤的后代类时,我的基类object
也获得了相同的分配,这破坏了从它扩展的所有其他内容。
相关代码见下图:
class object {
public static $global_filter;
public function _filterGlobal($class, $method, $callback) {
if ( !is_object($class::$global_filter) ) {
$class::$global_filter = new filterable(null);
# Replace the object being called with the new proxy.
}
var_dump($class);
var_dump($class::$global_filter); // `filterable`
var_dump(\core\blueprint\object::$global_filter); // Returns same as line above
die();
return $class::$global_filter->_add($method, $callback);
}
}
$class::$global_filter
和\core\blueprint\object::$global_filter
(基类)都返回相同的实例。而我希望object::$global_filter
是 null。
我没有使用后期静态绑定来保持一致性(单对象过滤器和全局过滤器都以相同的方式非静态地调用)。
任何帮助都感激不尽 :)
编辑,完整示例
这将是一个具体的类,它 extends model
which extendsobject
<?php
use core\blueprint\model;
class modelMock extends model {
protected $schema = array();
public function method($test) {
return $test;
}
}
这将是另一个对象(例如控制器),它也会扩展object
。它将过滤器应用于所有新实例model
<?php
use core\blueprint\object;
class objectMock extends object {
public function applyFilters() {
$this->_filterGlobal('core\blueprint\model', 'method', function($self, $chain) {
$chain->params[0] = 'new param'; // adjust the paramters
return $chain->next();
});
}
}