Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/design-patterns/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
我可以使用什么设计模式来模拟PHP中的traits/mixin?_Php_Design Patterns_Traits - Fatal编程技术网

我可以使用什么设计模式来模拟PHP中的traits/mixin?

我可以使用什么设计模式来模拟PHP中的traits/mixin?,php,design-patterns,traits,Php,Design Patterns,Traits,由于特性在PHP5.3AFAIK中不可用,我需要模拟它们提供的一些功能。接口无法工作,因为我需要具体的功能 问题: 我有两个客户端类,它们需要共享一些功能,但可以从不同的基类扩展 ClassA extends Foo {} ClassB extends Bar {} 我需要能够在两个类中实现一个名为getComponent()的函数,并且它的功能必须相同 更改基类不是一个选项。我在想这样做: Class ComponentHandler { function getInstance()

由于特性在PHP5.3AFAIK中不可用,我需要模拟它们提供的一些功能。接口无法工作,因为我需要具体的功能

问题: 我有两个客户端类,它们需要共享一些功能,但可以从不同的基类扩展

ClassA extends Foo {}

ClassB extends Bar {}
我需要能够在两个类中实现一个名为getComponent()的函数,并且它的功能必须相同

更改基类不是一个选项。我在想这样做:

Class ComponentHandler {
  function getInstance() {
    //return singleton
  }

  function getComponent() {
   //required functionality
  }
}

Class A extends Foo {

  var $handler;

  function __construct() {
    $this->handler = ComponentHandler::getInstance();
  }
}
$class = new ClassA();
$class->handler->getComponent();

$class = new ClassB();
$class->handler->getComponent();
我将在ClassA和ClassB中实现这个构造函数。在我的客户中,我会打这样的电话:

Class ComponentHandler {
  function getInstance() {
    //return singleton
  }

  function getComponent() {
   //required functionality
  }
}

Class A extends Foo {

  var $handler;

  function __construct() {
    $this->handler = ComponentHandler::getInstance();
  }
}
$class = new ClassA();
$class->handler->getComponent();

$class = new ClassB();
$class->handler->getComponent();

我更喜欢尽可能通过构造函数传递对象。您的方法依赖于类名
ComponentHandler
。通过构造函数传递对象并添加一个属性,您仍然在添加一个依赖项,但它允许您创建不同类型的
ComponentHandler
s

Class A extends Foo {
    var $handler;
    function __construct( ComponentHandler $handler ) {
         $this->handler = $handler
    }
}

$componentHandler = ComponentHandler::getInstance();
$class = new ClassA( $componentHandler );
类可以接受任何扩展ComponentHandler的处理程序,这也会起作用

Class ComponentHandler2 extends ComponentHandler {}
$componentHandler = ComponentHandler2::getInstance();
$class = new ClassA( $componentHandler2 );

我认为你提出的方法实际上是可行的(顺便说一句,它被称为)。请通过分别添加所需的空格来澄清ClassA和ClassA语法。同意@Brian-您所拥有的不仅足够,而且比使用Galen建议的实现(tho classic,仍然可用)[如下]引入更多DI要好。我想知道如何处理依赖关系。谢谢你的帮助。