Ok got it working like a charm using "proxy pattern" with traits. The idea being declaring the common methods inside a "trait" in order for extended and registered Node Classes to have access even if not derived / child of the extended DOMNode…
Here a small snippet :
<?php
namespace my;
trait tNode
{ // We need the magic method __get in order to add properties such as DOMNode->parentElement
public function __get($name)
{ if(property_exists($this, $name)){return $this->$name;}
if(method_exists($this, $name)){return $this->$name();}
throw new \ErrorException('my\\Node property \''.(string) $name.'\' not found…', 42, E_USER_WARNING);
}
// parentElement property definition
private function parentElement()
{ if($this->parentNode === null){return null;}
if($this->parentNode->nodeType === XML_ELEMENT_NODE){return $this->parentNode;}
return $this->parentNode->parentElement();
}
// JavaScript equivalent
public function isEqualNode(\DOMNode $node){return $this->isSameNode($node);}
public function compareDocumentPosition(\DOMNode $otherNode)
{ if($this->ownerDocument !== $otherNode->ownerDocument){return DOCUMENT_POSITION_DISCONNECTED;}
$c = strcmp($this->getNodePath(), $otherNode->getNodePath());
if($c === 0){return 0;}
else if($c < 0){return DOCUMENT_POSITION_FOLLOWING | ($c < -1 ? DOCUMENT_POSITION_CONTAINED_BY : 0);}
return DOCUMENT_POSITION_PRECEDING | ($c > 1 ? DOCUMENT_POSITION_CONTAINS : 0);
}
public function contains(\DOMNode $otherNode){return ($this->compareDocumentPosition($otherNode) >= DOCUMENT_POSITION_CONTAINED_BY);}
}
class Document extends \DomDocument
{ public function __construct($version=null, $encoding=null)
{ parent::__construct($version, $encoding);
$this->registerNodeClass('DOMNode', 'my\Node');
$this->registerNodeClass('DOMElement', 'my\Element');
$this->registerNodeClass('DOMDocument', 'my\Document');
/* [...] */
}
}
class Element extends \DOMElement
{ use tNode;
/* [...] */
}
class Node extends \DOMNode
{ use tNode;
/* [...] */
}
?>
PHP.mk документација
DOMImplementation
Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.
Патека
class.domimplementation.php
Локална патека за оваа страница.
Извор
php.net/manual/en
Оригиналниот HTML се реупотребува и локално се стилизира.
Режим
Прокси + преведен приказ
Кодовите, табелите и белешките остануваат читливи во истиот тек.
Референца
class.domimplementation.php
DOMImplementation
Референца за `class.domimplementation.php` со подобрена типографија и навигација.
Класата DOMImplementation
класата mysqli_driver
Вовед
Оваа класа обезбедува голем број методи за извршување операции кои се независни од која било конкретна инстанца на DOM (Document Object Model).
Синопсис на класата
class DOMImplementation
{
/* Методи */
public createDocument(?string
$namespace = null, string $qualifiedName = "", ?DOMDocumentType $doctype = null): DOMDocumentpublic createDocumentType(string
}$qualifiedName, string $publicId = "", string $systemId = ""): DOMDocumentType|falseСодржина
- DOMImplementation::__construct — Создава нов објект DOMImplementation
- DOMImplementation::createDocument — Создава DOMDocument објект од наведениот тип со неговиот документ елемент
- DOMImplementation::createDocumentType — Создава празен објект DOMDocumentType
- DOMImplementation::hasFeature — Тестира дали DOM имплементацијата имплементира специфична функција
Белешки од корисници 1 белешка
LANGE.LUDO ¶
пред 11 години