Я нещодавно тільки імпортував весь вміст з блогу веб-сайту в WordPress, і мені потрібно трохи попрактикуватись.
Я працюю всередині single.php, і я хочу отримати кожен <a><img src="/images/"/></a>
від the_content();
. Мій php трохи підроблений в кращому випадку.
Я розумію, що це дає мені перше зображення публікації, але мені потрібно щось подібне, той, який отримує мені всі зображення (не відмічені зображеннями) від the_content();
.
function catch_that_image() {
global $post, $posts;
$first_img = "";
ob_start();
ob_end_clean();
$output = preg_match_all("/<img.+src=[""]([^""]+)[""].*>/i", $post->post_content, $matches);
$first_img = $matches[1][0];
if(empty($first_img)) {
$first_img = "/path/to/default.png";
}
return $first_img;
}
Відповіді:
4 для відповіді № 1Погляньте на власний об'єкт DOMDocument PHP. http://www.php.net/manual/en/class.domdocument.php
Ви візьмете свій вміст і завантажте його в DOMDocument через loadHTML()
. Тоді ви можете використовувати getElementsByTagName()
щоб отримати всі зображення.
http://www.php.net/manual/en/domdocument.getelementsbytagname.php
$document = new DOMDocument();
$document->loadHTML($post->post_content);
$images = $document->getElementsByTagName("img");
2 для відповіді № 2
Тривіальне завдання для DOMDocument
:
$doc = new DOMDocument();
$doc->loadHTML($post->post_content);
foreach ($doc->getElementsByTagName("img") as $img)
$img->attributes["src"] = "/path/to/default.png"; // or whatever you want to do
return $doc->saveHTML();
Потрібно стежити за тим, saveHTML()
може додати відсутні мітки навколо вашої структури.