У меня есть два класса а именно Foo & BarPHP реализует ArrayAccess
class bar extends foo
{
public $element = null;
public function __construct()
{
}
}
и Foo класса идет как
class foo implements ArrayAccess
{
private $data = [];
private $elementId = null;
public function __call($functionName, $arguments)
{
if ($this->elementId !== null) {
echo "Function $functionName called with arguments " . print_r($arguments, true);
}
return true;
}
public function __construct($id = null)
{
$this->elementId = $id;
}
public function offsetSet($offset, $value)
{
if (is_null($offset)) {
$this->data[] = $value;
} else {
$this->data[$offset] = $value;
}
}
public function offsetExists($offset)
{
return isset($this->data[$offset]);
}
public function offsetUnset($offset)
{
if ($this->offsetExists($offset)) {
unset($this->data[$offset]);
}
}
public function offsetGet($offset)
{
if (!$this->offsetExists($offset)) {
$this->$offset = new foo($offset);
}
}
}
я хочу, когда я запускаю ниже фрагмент кода:
$a = new bar();
$a['saysomething']->sayHello('Hello Said!');
должен возвращать Функция sayHello Вызывается с аргументами Привет Сказал! из foo's __call magic method.
Здесь я хочу сказать saysomething должен быть принят в $ this-> elementId из __construct функции Foo и SayHello следует рассматривать как метод и Здравствуйте Упомянутая должны быть приняты как параметров для sayHello Функция, которая будет отображаться от __call magic method.
Кроме того, необходимо методы цепи, как:
$a['saysomething']->sayHello('Hello Said!')->sayBye('Good Bye!');
удивительно эффективно! Спасибо тонну @ Jack! – Guns
@Guns Добро пожаловать; что '$ bar ['saysomething']' не возвращает объект 'bar', а объект' foo'. –
спасибо !. Это работает отлично, однако, когда я цепи методы это не работает. Я пытаюсь '$ a ['sayomething'] -> sayHello ['Hello Said!] -> sayBye (' Good Bye! ');'. Как мне это достичь? – Guns