Home Backend Development PHP Tutorial How to dynamically compress js and css files using PHP

How to dynamically compress js and css files using PHP

May 02, 2018 pm 04:39 PM
css javascript

这篇文章主要介绍了关于PHP实现动态压缩js与css文件的方法,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

本文实例讲述了PHP实现动态压缩js与css文件的方法。分享给大家供大家参考,具体如下:

正式发布产品时,我们希望将项目里的js,css合并压缩,以减少http请求、防止轻易查看源代码。

使用

只需要在头部引入一下代码即可:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

<meta charset="utf-8"/>

<title>demo</title>

<?php

//定义需要压缩的文件

$css = array(

CSS_PATH . 'base.css',

CSS_PATH . 'style.css',

CSS_PATH . 'my.css'

);

$js = array(

PUB_PATH . '/lib/zepto.min.js',

PUB_PATH . '/js/1.js',

JS_PATH . '2.js',

);

$css_path = base_url(parse_css($css));

$js_path = base_url(parse_script($js));

?>

<link rel="stylesheet" type="text/css" href="<?php echo $css_path ?>" rel="external nofollow" >

<script src="<?php echo $js_path ?>"></script>

<!--下面可以继续放不能压缩或者不想压缩的文件-->

<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>

Copy after login

这段代码会在指定的目录(例如common/)里生成压缩过后的js和css.每次更新了js,css内容,请先删除生成的压缩文件。

示例:

1

2

4e387d5edce14cc2bd6396f6ebb7921b.css

7c10211f113f3175489196d336d67734.js

Copy after login

注意:

编写的css和js文件一定要符合规范。例如一定要加分号。js的function可以不加分号。

引用的资源

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

/**

*  合并压缩css

*/

function parse_css($urls)

{

  $url = md5(implode(',', $urls));

  $path = FCPATH. 'static/parse/';

  $css_url = $path . $url . '.css';

  if (!file_exists($css_url)) {

    if (!file_exists($path))

      mkdir($path, 0777);

    $css_content = '';

    foreach ($urls as $url) {

      $css_content .= @file_get_contents($url);

    }

    $css_content = str_replace("\r\n", '', $css_content); //清除换行符

    $css_content = str_replace("\n", '', $css_content); //清除换行符

    $css_content = str_replace("\t", '', $css_content); //清除制表符

    $css_content = str_replace("../images/", "./../common/images/", $css_content);

    @file_put_contents($css_url, $css_content);

  }

  $css_url = str_replace(FCPATH, '', $css_url);

  return $css_url;

}

/**

*  合并压缩js

*/

function parse_script($urls)

{

  $url = md5(implode(',', $urls));

  $path = FCPATH. '/static/parse/';

  $js_url = $path . $url . '.js';

  if (!file_exists($js_url)) {

    if (!file_exists($path))

      mkdir($path, 0777);

    load_qy_lib('JavaScriptPacker');

    $js_content = '';

    foreach ($urls as $url) {

      $append_content = @file_get_contents($url) . "\r\n";

      $packer = new JavaScriptPacker($append_content);

      $append_content = $packer->_basicCompression($append_content);

      $js_content .= $append_content;

    }

    @file_put_contents($js_url, $js_content);

  }

  $js_url = str_replace(FCPATH, '', $js_url);

  return $js_url;

}

Copy after login

项目里引用到第三方类库JavaScriptPacker可以在github下载:

gkralik/php-uglifyjs
https://github.com/gkralik/php-uglifyjs

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

/**

 * 9 April 2008. version 1.1

 *

 * This is the php version of the Dean Edwards JavaScript's Packer,

 * Based on :

 *

 * ParseMaster, version 1.0.2 (2005-08-19) Copyright 2005, Dean Edwards

 * a multi-pattern parser.

 * KNOWN BUG: erroneous behavior when using escapeChar with a replacement

 * value that is a function

 *

 * packer, version 2.0.2 (2005-08-19) Copyright 2004-2005, Dean Edwards

 *

 * License: http://creativecommons.org/licenses/LGPL/2.1/

 *

 * Ported to PHP by Nicolas Martin.

 *

 * ----------------------------------------------------------------------

 * changelog:

 * 1.1 : correct a bug, '\0' packed then unpacked becomes '\'.

 * ----------------------------------------------------------------------

 *

 * Changes:

 * 2014-08-28: grkalik: change class for composer support. no functionality change.

 *

 */

Copy after login

相关推荐:

PHP实现执行外部程序的方法详解

PHP实现动态获取函数参数的方法


The above is the detailed content of How to dynamically compress js and css files using PHP. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot Article Tags

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

What does placeholder mean in vue What does placeholder mean in vue May 07, 2024 am 09:57 AM

What does placeholder mean in vue

How to write spaces in vue How to write spaces in vue Apr 30, 2024 am 05:42 AM

How to write spaces in vue

What does span mean in js What does span mean in js May 06, 2024 am 11:42 AM

What does span mean in js

How to get dom in vue How to get dom in vue Apr 30, 2024 am 05:36 AM

How to get dom in vue

What does rem mean in js What does rem mean in js May 06, 2024 am 11:30 AM

What does rem mean in js

How to introduce images into vue How to introduce images into vue May 02, 2024 pm 10:48 PM

How to introduce images into vue

What is the function of span tag What is the function of span tag Apr 30, 2024 pm 01:54 PM

What is the function of span tag

What language is the browser plug-in written in? What language is the browser plug-in written in? May 08, 2024 pm 09:36 PM

What language is the browser plug-in written in?

See all articles