當前位置: 首頁>>代碼示例>>PHP>>正文


PHP DOMDocument::normalize方法代碼示例

本文整理匯總了PHP中DOMDocument::normalize方法的典型用法代碼示例。如果您正苦於以下問題:PHP DOMDocument::normalize方法的具體用法?PHP DOMDocument::normalize怎麽用?PHP DOMDocument::normalize使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在DOMDocument的用法示例。


在下文中一共展示了DOMDocument::normalize方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: assertXMLEquals

 protected function assertXMLEquals($expect, $test)
 {
     $doc = new DOMDocument();
     $this->assertTrue($doc->loadXML($expect), "Can load {$expect}");
     $doc->normalize();
     $expect = $doc->saveXML();
     $doc = new DOMDocument();
     $this->assertTrue($doc->loadXML($test), "Can load {$test}");
     $doc->normalize();
     $test = $doc->saveXML();
     $this->assertEquals($expect, $test);
 }
開發者ID:gbisra,項目名稱:Computer-r-us,代碼行數:12,代碼來源:config.php

示例2: process

 /**
  * HTML processor
  * @param string $source Source HTML
  * @param bool $clean Perform cleaning
  * @param bool $withHeaders Return full HTML page (true) or contents only (false)
  * @return string
  */
 public function process($source, $clean = true, $withHeaders = false)
 {
     if (!trim($source)) {
         return '';
     }
     /*try {
           $source = \Difra\Libs\ESAPI::encoder()->canonicalize( $source );
       } catch( \Exception $ex ) {
           return false;
       }*/
     // html to dom conversion
     $html = new \DOMDocument('1.0');
     libxml_use_internal_errors(true);
     $html->loadHTML('<?xml version = "1.0" encoding = "utf-8"?>' . $source);
     libxml_use_internal_errors(false);
     $html->normalize();
     // clean dom
     if ($clean) {
         $bodyList = $html->documentElement->getElementsByTagName('body');
         if ($bodyList->length and $bodyList->item(0)->childNodes->length) {
             $body = $bodyList->item(0);
             $replaceNodes = [];
             foreach ($body->childNodes as $node) {
                 $newReplaceNodes = $this->clean($node);
                 $replaceNodes = array_merge($replaceNodes, $newReplaceNodes);
             }
             if (!empty($replaceNodes)) {
                 foreach ($replaceNodes as $replaceNode) {
                     $this->replace($replaceNode);
                 }
             }
         } else {
             return false;
         }
     }
     // dom to html conversion
     if ($withHeaders) {
         $output = $html->saveHTML();
     } else {
         $newDom = new \DOMDocument();
         foreach ($html->documentElement->childNodes as $node) {
             if ($node->nodeName == 'body') {
                 foreach ($node->childNodes as $subNode) {
                     $newDom->appendChild($newDom->importNode($subNode, true));
                 }
             }
         }
         $output = $newDom->saveHTML();
         // TODO: convert xhtml to html5
     }
     return mb_convert_encoding($output, 'UTF-8', 'HTML-ENTITIES');
 }
開發者ID:difra-org,項目名稱:difra,代碼行數:59,代碼來源:HTML.php

示例3: xmlDump

 public static function xmlDump($var)
 {
     $oDM = new DOMDocument();
     $oDM->loadXML($var);
     if ($oDM) {
         $oDM->formatOutput = true;
         $oDM->normalize();
         $var = $oDM->saveXML();
         $widget = new CTextHighlighter();
         $widget->language = 'xml';
         echo $widget->highlight(${$var});
     }
 }
開發者ID:niranjan2m,項目名稱:Voyanga,代碼行數:13,代碼來源:VarDumper.php

示例4: formatXML

 public static function formatXML($xml)
 {
     libxml_use_internal_errors(true);
     $oDM = new DOMDocument();
     try {
         $load = @$oDM->loadXML($xml);
         if ($load) {
             $oDM->formatOutput = true;
             $oDM->normalize();
             $xml = $oDM->saveXML();
         }
     } catch (Exeption $e) {
     }
     return $xml;
 }
開發者ID:niranjan2m,項目名稱:Voyanga,代碼行數:15,代碼來源:UtilsHelper.php

示例5: toXML

function toXML()
{
    global $sheet, $file;
    if ($sheet === null) {
        return;
    }
    $doc = new DOMDocument('1.0', 'utf-8');
    $doc->preserveWhiteSpace = false;
    $doc->formatOutput = true;
    $root = $doc->createElement("character");
    $doc->appendChild($root);
    $gear = $doc->createElement("gear");
    $root->appendChild($gear);
    $fileName = $file;
    foreach ($sheet as $key => $value) {
        switch ($key) {
            case "monk":
            case "priest":
            case "shaman":
            case "druid":
            case "warlock":
            case "warrior":
            case "hunter":
            case "deathknight":
            case "rogue":
            case "mage":
            case "paladin":
                $fileName = $value["value"];
                $root->setAttribute("name", $value["value"]);
                $root->setAttribute("class", $key);
                break;
            case "level":
                $root->setAttribute("level", $value["value"]);
                break;
            case "race":
                $root->setAttribute("race", $value["value"]);
                break;
            case "role":
                $root->setAttribute("role", $value["value"]);
                break;
            case "head":
            case "neck":
            case "shoulder":
            case "chest":
            case "waist":
            case "legs":
            case "feet":
            case "wrist":
            case "finger1":
            case "finger2":
            case "trinket1":
            case "trinket2":
            case "back":
            case "main_hand":
            case "off_hand":
                $e = $doc->createElement("item");
                $e->setAttribute("slot", $key);
                $vars = $value["vars"];
                foreach ($vars as $vkey => $vvalue) {
                    $e->setAttribute($vkey, $vvalue);
                }
                $e->appendChild($doc->createTextNode($value["value"]));
                $gear->appendChild($e);
                break;
            default:
        }
    }
    $doc->normalize();
    $length = strrpos($fileName, ".");
    if (!$length) {
        $length = strlen($fileName);
    }
    $f = substr($fileName, 0, $length) . ".xml";
    $doc->save($f);
    return $doc;
}
開發者ID:recognant,項目名稱:guidesite,代碼行數:76,代碼來源:index.php

示例6: prettyprint

 /**
  * prettyprint -- get rid of superfluous namespace declarations
  * @param  DOMDocument $dom
  * @return DOMDocument       return cleaned DOM
  */
 private function prettyprint($dom)
 {
     $dom->normalize();
     $dom->preserveWhiteSpace = false;
     $dom->formatOutput = true;
     $outXML = $dom->saveXML();
     $dom->loadXML($outXML, LIBXML_NSCLEAN);
     return $dom;
 }
開發者ID:Nothorse,項目名稱:Giles,代碼行數:14,代碼來源:opds.cls.php

示例7:

<txt>
\t<txt lines="1">
\t\t<txt lines="nope"></txt>
\t</txt>
\t<txt lines="0">
\t\t<txt lines="12"></txt>
\t  <txt lines="3">
\t    <txt lines-after="2"></txt>
\t    <txt></txt>
\t  </txt>
\t\t<txt lines-before="2"></txt>
\t</txt>
</txt>
EOS
);
$dom->normalize();
$xpath = new \DOMXPath($dom);
$root = $xpath->query('/txt')->item(0);
//$r = $xpath->evaluate(
//'.//txt[last() and ancestor::txt[last()]]',
//$root
//);
//$it = $root;
//$lines = 0;
//while(($it = $it->lastChild )&& $it instanceof DOMElement) {
//var_dump($it->getNodePath());
//if($it->hasAttribute('lines')) {
//$line = (int) $it->getAttribute('lines');
//var_dump($line);
//if($line > $lines) $lines = $line;
//}
開發者ID:ju1ius,項目名稱:libphp,代碼行數:31,代碼來源:PlainText.php


注:本文中的DOMDocument::normalize方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。