首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将src/srcset替换为data-srcset/data-src

将src/srcset替换为data-srcset/data-src
EN

Stack Overflow用户
提问于 2018-10-30 22:45:15
回答 1查看 574关注 0票数 1

我想将lozad.js脚本应用到我的wordpress/woocommerce前端。为此,我需要将src更改为data-src。这是我到目前为止所拥有的代码,但不能正常工作。

谢谢你的帮忙!

代码语言:javascript
复制
    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 = 'https://d1zczzapudl1mr.cloudfront.net/blank-kraken.gif';
                 $node->setAttribute('src', $newsrc);

                 $oldsrcset = $node->getAttribute('srcset');
                 $node->setAttribute('data-srcset', $oldsrcset );
                 $newsrcset = '';
                 $node->setAttribute('srcset', $newsrcset);

                 $classes = $node->getAttribute('class');
                 $newclasses = $classes . ' lozad';
                 $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', 10);
EN

回答 1

Stack Overflow用户

发布于 2018-10-30 23:18:48

有没有更简单的东西?

代码语言:javascript
复制
str_replace('<img src=','<img data-src=',$html);

或者一些正则表达式?

票数 -3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53066897

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档