wordpress纯代码实现前端页面压缩

技术论点 Loading... 阅读 0

前端代码压缩能有效缩小页面大小,减少传输时间,从而减少用户访问的等待时间。

使用下面的这个方法前提是,你的服务器性能要足够,因为代码生成是需要时间压缩页面再返回给前端的。我个人建议使用缓存插件搭配这个代码使用,这样能第一次压缩之后缓存在节点或者本地,从而下次用户访问直接调用对于的html文件,不需要程序再次压缩代码返回了。

wordpress纯代码实现前端页面压缩

用法:

将下面的代码放到 你当前主题的 functions.php 文件中,建议放在最底部,这样不容易出错。

代码:

// 压缩前端代码  https://www.linpx.com/p/pinghsu-subject-integration-code-compression.html
function mk_compress_html_main($html_source) {
    $chunks = preg_split('/(.*?|.*?<\/nocompress>|||)/msi', $html_source, -1, PREG_SPLIT_DELIM_CAPTURE); $compress = ''; foreach ($chunks as $c) { if (strtolower(substr($c, 0, 19)) == '') { $c = substr($c, 19, strlen($c) - 19 - 20); $compress .= $c; continue; } else if (strtolower(substr($c, 0, 12)) == '') { $c = substr($c, 12, strlen($c) - 12 - 13); $compress .= $c; continue; } else if (strtolower(substr($c, 0, 4)) == ' $char) {
                        if ($char == '"' && $chars[$key - 1] != '\\' && !$is_apos) {
                            $is_quot = !$is_quot;
                        } else if ($char == '\'' && $chars[$key - 1] != '\\' && !$is_quot) {
                            $is_apos = !$is_apos;
                        } else if ($char == '/' && $chars[$key + 1] == '/' && !$is_quot && !$is_apos) {
                            $tmp = substr($tmp, 0, $key);
                            break;
                        }
                    }
                }
                $c .= $tmp;
            }
        }
        $c = preg_replace('/[\\n\\r\\t]+/', ' ', $c);
        $c = preg_replace('/\\s{2,}/', ' ', $c);
        $c = preg_replace('/>\\s <', $c);
        // 去除注释(可选)
        // $c = preg_replace('/\\/\\*.*?\\*\\//i', '', $c);
        // $c = preg_replace('//', '', $c);
        $compress .= $c;
    }
    return $compress;
}
function mk_compress_html() {
    ob_start('mk_compress_html_main');
}
add_action('get_header', 'mk_compress_html');

Tags:

版权声明:若无特殊注明,本文皆为《长行客》原创,转载务必保留文章来源。

本文链接:wordpress纯代码实现前端页面压缩 & https://www.mxooo.cn/1175/

推荐阅读
发表评论 取消回复
表情 图片 链接 代码

分享