Я использую эту функцию для преобразования моих изображений WordPress в формат LazyLoad:
// Lazyload Converter
function add_lazyload($content) {
$content = mb_convert_encoding($content, 'HTML-ENTITIES', "UTF-8");
$dom = new DOMDocument();
@$dom->loadHTML($content);
// Convert Images
$images = [];
foreach ($dom->getElementsByTagName('img') as $node) {
$images[] = $node;
}
foreach ($images as $node) {
$fallback = $node->cloneNode(true);
$oldsrc = $node->getAttribute('src');
$node->setAttribute('data-src', $oldsrc );
$newsrc = '';
$node->setAttribute('src', $newsrc);
$oldsrcset = $node->getAttribute('srcset');
$node->setAttribute('data-srcset', $oldsrcset );
$newsrcset = '';
$node->setAttribute('srcset', $newsrcset);
$classes = $node->getAttribute('class');
$newclasses = $classes . ' lazy';
$node->setAttribute('class', $newclasses);
$noscript = $dom->createElement('noscript', '');
$node->parentNode->insertBefore($noscript, $node);
$noscript->appendChild($fallback);
}
// Convert Videos
$videos = [];
foreach ($dom->getElementsByTagName('iframe') as $node) {
$videos[] = $node;
}
foreach ($videos as $node) {
$fallback = $node->cloneNode(true);
$oldsrc = $node->getAttribute('src');
$node->setAttribute('data-src', $oldsrc );
$newsrc = '';
$node->setAttribute('src', $newsrc);
$classes = $node->getAttribute('class');
$newclasses = $classes . ' lazy';
$node->setAttribute('class', $newclasses);
$noscript = $dom->createElement('noscript', '');
$node->parentNode->insertBefore($noscript, $node);
$noscript->appendChild($fallback);
}
$newHtml = preg_replace('/^<!DOCTYPE.+?>/', '', str_replace( array('<html>', '</html>', '<body>', '</body>'), array('', '', '', ''), $dom->saveHTML()));
return $newHtml;
}
add_filter('the_content', 'add_lazyload');
add_filter('post_thumbnail_html', 'add_lazyload');
Вывод изображения выглядит следующим образом:
<img src="" alt="" class="wp-image-7035 lazy" srcset="" sizes="(max-width: 720px) 100vw, 720px" data-src="http://localhost/wp-content/uploads/2020/01/unsplash-1.jpg" data-srcset="http://localhost/wp-content/uploads/2020/01/unsplash-1.jpg 720w, http://localhost/wp-content/uploads/2020/01/unsplash-1-300x300.jpg 300w, http://localhost/wp-content/uploads/2020/01/unsplash-1-150x150.jpg 150w">
Проблема: проверка html не выполнена из-за пустого атрибута srcset. Как я могу это исправить?
Я думаю, мне нужно что-то вроде:
if ( $img->hasAttribute( 'sizes' ) && $img->hasAttribute( 'srcset' ) ) {
, но я не знаю, как это реализовать, потому что мои знания php очень ограничены .
Заранее спасибо!