<?php | |
class WP_HTML_Compression | |
{ | |
// Settings | |
protected $compress_css = true; | |
protected $compress_js = true; | |
protected $info_comment = true; | |
protected $remove_comments = true; | |
// Variables | |
protected $html; | |
public function __construct($html) | |
{ | |
if (!empty($html)) | |
{ | |
$this->parseHTML($html); | |
} | |
} | |
public function __toString() | |
{ | |
return $this->html; | |
} | |
protected function bottomComment($raw, $compressed) | |
{ | |
$raw = strlen($raw); | |
$compressed = strlen($compressed); | |
$savings = ($raw-$compressed) / $raw * 100; | |
$savings = round($savings, 2); | |
return '<!--HTML compressed, size saved '.$savings.'%. From '.$raw.' bytes, now '.$compressed.' bytes-->'; | |
} | |
protected function minifyHTML($html) | |
{ | |
$pattern = '/<(?<script>script).*?<\/script\s*>|<(?<style>style).*?<\/style\s*>|<!(?<comment>--).*?-->|<(?<tag>[\/\w.:-]*)(?:".*?"|\'.*?\'|[^\'">]+)*>|(?<text>((<[^!\/\w.:-])?[^<]*)+)|/si'; | |
preg_match_all($pattern, $html, $matches, PREG_SET_ORDER); | |
$overriding = false; | |
$raw_tag = false; | |
// Variable reused for output | |
$html = ''; | |
foreach ($matches as $token) | |
{ | |
$tag = (isset($token['tag'])) ? strtolower($token['tag']) : null; | |
$content = $token[0]; | |
if (is_null($tag)) | |
{ | |
if ( !empty($token['script']) ) | |
{ | |
$strip = $this->compress_js; | |
} | |
else if ( !empty($token['style']) ) | |
{ | |
$strip = $this->compress_css; | |
} | |
else if ($content == '<!--wp-html-compression no compression-->') | |
{ | |
$overriding = !$overriding; | |
// Don't print the comment | |
continue; | |
} | |
else if ($this->remove_comments) | |
{ | |
if (!$overriding && $raw_tag != 'textarea') | |
{ | |
// Remove any HTML comments, except MSIE conditional comments | |
$content = preg_replace('/<!--(?!\s*(?:\[if [^\]]+]|<!|>))(?:(?!-->).)*-->/s', '', $content); | |
} | |
} | |
} | |
else | |
{ | |
if ($tag == 'pre' || $tag == 'textarea') | |
{ | |
$raw_tag = $tag; | |
} | |
else if ($tag == '/pre' || $tag == '/textarea') | |
{ | |
$raw_tag = false; | |
} | |
else | |
{ | |
if ($raw_tag || $overriding) | |
{ | |
$strip = false; | |
} | |
else | |
{ | |
$strip = true; | |
// Remove any empty attributes, except: | |
// action, alt, content, src | |
$content = preg_replace('/(\s+)(\w++(?<!\baction|\balt|\bcontent|\bsrc)="")/', '$1', $content); | |
// Remove any space before the end of self-closing XHTML tags | |
// JavaScript excluded | |
$content = str_replace(' />', '/>', $content); | |
} | |
} | |
} | |
if ($strip) | |
{ | |
$content = $this->removeWhiteSpace($content); | |
} | |
$html .= $content; | |
} | |
return $html; | |
} | |
public function parseHTML($html) | |
{ | |
$this->html = $this->minifyHTML($html); | |
if ($this->info_comment) | |
{ | |
$this->html .= "\n" . $this->bottomComment($html, $this->html); | |
} | |
} | |
protected function removeWhiteSpace($str) | |
{ | |
$str = str_replace("\t", ' ', $str); | |
$str = str_replace("\n", '', $str); | |
$str = str_replace("\r", '', $str); | |
while (stristr($str, ' ')) | |
{ | |
$str = str_replace(' ', ' ', $str); | |
} | |
return $str; | |
} | |
} | |
function wp_html_compression_finish($html) | |
{ | |
return new WP_HTML_Compression($html); | |
} | |
function wp_html_compression_start() | |
{ | |
ob_start('wp_html_compression_finish'); | |
} | |
add_action('get_header', 'wp_html_compression_start'); | |
?> |
This comment has been minimized.
This comment has been minimized.
That's Awesome! |
This comment has been minimized.
This comment has been minimized.
That's works! Thanks. |
This comment has been minimized.
This comment has been minimized.
Working gratefully .. Thanks a lot! |
This comment has been minimized.
This comment has been minimized.
Working great Seth. Thanks! |
This comment has been minimized.
This comment has been minimized.
Life saver!! |
This comment has been minimized.
This comment has been minimized.
It only compresses HTML in |
This comment has been minimized.
This comment has been minimized.
Works fine but i have problems in some premium templates. |
This comment has been minimized.
This comment has been minimized.
Works for me. |
This comment has been minimized.
This comment has been minimized.
Really help full. |
This comment has been minimized.
This comment has been minimized.
nice effort for make this code, thank's |
This comment has been minimized.
This comment has been minimized.
Thanks. It's a good one but aint working on https( Is any ideas what it cant be? |
This comment has been minimized.
This comment has been minimized.
It was removing the schema added to html is there any possibility to do without affecting schema ? |
This comment has been minimized.
This comment has been minimized.
This is great! |
This comment has been minimized.
This comment has been minimized.
I wrote this script in 2015, five years ago, so I would expect for it to cause some plugins to function incorrectly. To my surprise it's still useful in several use cases after 5 years of WordPress updates. Thanks for the comments everyone! |
This comment has been minimized.
This comment has been minimized.
It's great. Thanks a lot! |
This comment has been minimized.
This comment has been minimized.
Wow! Thanks! <3 |
This comment has been minimized.
This comment has been minimized.
For those who have a problem with the display of Revolution Slider. You can solve the problem by adding your 2 'setREVStartSize' scripts that you can find in the header and the body of your page source script, (Take care to remove the <script> </script> tags of your JS script) Add your files in the FTP directory like this : wp-content / plugins / revslider / public / assets / js / File1.js & wp-content / plugins / revslider / public / assets / js / File2.js Then you can use the plugin name : Insert Headers and Footers And Finally insert your scripts like this: <script type = 'text / javascript' src = 'https: //www.site.com/wp-content/plugins/revslider/public/assets/js/file1.js'> & <script type = 'text / javascript' src = 'https: //www.site.com/wp-content/plugins/revslider/public/assets/js/file2.js'> Taking care to respect the location of the tags that were either in the header or in the body. And now everything is working. Sorry for my faults, English level in France is very poor :) |
This comment has been minimized.
This comment has been minimized.
//This is how Autoptimize plugin fix the Revslider issue. |
This comment has been minimized.
Hey Seth, works like a charm and compresses HTML, but I've noticed it disables Revolution Slider from displaying. Any thoughts?