>백엔드 개발 >PHP 튜토리얼 >블록 수준 요소를 잃지 않고 DOMDocument에서 HTML을 저장하는 방법은 무엇입니까?

블록 수준 요소를 잃지 않고 DOMDocument에서 HTML을 저장하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-18 10:11:17888검색

How to Save HTML from a DOMDocument Without Losing Block-Level Elements?

블록 수준 요소를 생략하지 않고 DOMDocument의 HTML을 저장하는 방법

DOMDocument의 내용을 HTML로 저장하려고 할 때 문제가 발생합니다. 기본 HTML, 본문 및 p 태그 래퍼를 포함하지 않습니다. saveXML($d->getElementsByTagName('p')->item(0))을 사용하는 제안된 솔루션은 콘텐츠에 블록 수준 요소가 없는 경우에만 작동합니다.

기존 접근 방식

h1 태그와 같은 블록 수준 요소가 있는 경우 saveXML의 출력은 다음과 같습니다. 잘리고 p 태그 내의 텍스트만 남깁니다.

업데이트된 접근 방식

이 문제를 해결하려면 PHP에 도입된 loadHTML 함수의 업데이트된 버전을 활용할 수 있습니다. 5.4 및 Libxml 2.6. 이 함수에는 콘텐츠를 구문 분석하는 방법을 지정할 수 있는 $options 매개 변수가 포함되어 있습니다. 다음 옵션을 설정하여:

$html->loadHTML($content, LIBXML_HTML_NOIMPLIED | LIBXML_HTML_NODEFDTD);

옵션 설명

  • LIBXML_HTML_NOIMPLIED는 묵시적인 html/본문 요소의 자동 추가를 비활성화합니다.
  • LIBXML_HTML_NODEFDTD는 기본 문서 유형이 추가되는 것을 방지합니다. 찾을 수 없는 경우.

나중에 saveHTML()을 수행하면 출력에 doctype, html 태그 또는 body 태그가 포함되지 않습니다. 이 접근 방식을 사용하면 블록 수준 요소가 출력에 유지됩니다.

참고:

  • Libxml 2.6 문서에는 Libxml 2.6이 필요하다고 명시되어 있지만 LIBXML_HTML_NODEFDTD Libxml에서만 사용 가능 2.7.8.
  • LIBXML_HTML_NOIMPLIED는 Libxml 2.7.7에서 사용할 수 있습니다.

위 내용은 블록 수준 요소를 잃지 않고 DOMDocument에서 HTML을 저장하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.