定制 sema/minifier-bundle 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

sema/minifier-bundle

Composer 安装命令:

composer require sema/minifier-bundle

包简介

This bundle allows you to minify html code, combine and minify JavaScript files and CSS files without Java VM.

README 文档

README

This Symfony2 bundle allows you to minify html code, combine and minify JavaScript files and CSS files without Java VM.

Installation

Install using composer.json

If you are using composer to manage your project, just add the following line to your composer.json file

{
    "require": {
    	"sema/minifier-bundle": "dev-master"
    }
}

Then update the vendor libraries:

composer.phar update
# OR
composer.phar update sema/minifier-bundle # to only update the bundle

Register the bundle

You must register the bundle in your kernel:

<?php

// app/AppKernel.php
public function registerBundles()
{
    $bundles = array(
        // ...
        new Sema\Bundle\MinifierBundle\SemaMinifierBundle(),
    );
    // ...
}

#Use

You have two options for minify html:

  1. onKernelResponse listener
  2. Twig Extension

Enable minify html using onKernelResponse listener

You need add follow lines in config.yml

    #app/config.yml
    sema_minifier:
        enable_listener: true

All responses will be minified

Enable minify html using Twig Extension

You need modify base template (base.html.twig or layout.html.twig or something else), add {% minifyhtml %} to the top of the file and {% endminifyhtml %} to the bottom of the file. You need get something like this

    #base.html.twig
    {% minifyhtml %}
    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8" />
            <title>{% block title %}Welcome!{% endblock %}</title>
            {% block stylesheets %}{% endblock %}
            <link rel="icon" type="image/x-icon" href="{{ asset('favicon.ico') }}" />
        </head>
        <body>
            {% block body %}{% endblock %}
            {% block javascripts %}{% endblock %}
        </body>
    </html>
    {% endminifyhtml %}

##Use combine and minify js or css files The configuration file is a JSON file that describes all the rules for combining static files. Each group is assigned a file name to which we refer in the templates. This allows you to not get attached to the physical location of the file, which can be handy when you change the file structure. Below is a sample configuration file assets.json

{
    "css": {
        "main": {
            "output": "assets/css/dist/main.min.css",
            "input": [
                "bundles/framework/css/structure.css",
                "bundles/framework/css/body.css"
            ]
        }
    },
    "js": {
        "vendor": {
            "output": "assets/js/dist/vendor.min.js",
            "input": [
                "assets/libs/jquery/dist/jquery.js"
            ]
        },
        "html5shiv": {
            "output": "assets/js/dist/html5shiv.min.js",
            "input": "assets/libs/html5shiv/dist/html5shiv.js"
        },
        "form": {
            "output": "assets/js/dist/form.min.js",
            "input": [
                "assets/libs/parsleyjs/dist/parsley.js",
                "assets/libs/jquery-ui/jquery-ui.js",
                "assets/js/form.js"
            ]
        }
    }
}

Depending on the debug mode expansion will transmit a pattern or an array of source files, or an array of processed files. Here is an example template:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title>{% block title %}Welcome!{% endblock %}</title>
        {% block stylesheets %}
          {% for url in assets.css['main'] %}
              <link rel="stylesheet" href="{{ asset(url) }}" />
          {% endfor %}
        {% endblock %}
        <!--[if lt IE 9]>
            <script src="{{ asset(assets.js['html5shiv'][0], version='1') }}"></script>
        <![endif]-->
        <link rel="icon" type="image/x-icon" href="{{ asset('favicon.ico') }}" />
    </head>
    <body>
        {% block body %}{% endblock %}
        {% block javascripts %}
          {% for url in assets.js['vendor'] %}
              <script src="{{ asset(url) }}"></script>
          {% endfor %}
        {% endblock %}
    </body>
</html>

统计信息

  • 总下载量: 12.86k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 6
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 5
  • Watchers: 3
  • Forks: 11
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-02-17