js,css 文件合并与压缩

Grunt 是前端自动化构建工具,类似webpack。 它究竟有多强悍,请看它的 介绍

这里只演示如何用它的皮毛功能:文件合并与压缩。

首先说下js,css 合并与压缩的好处:

  • 减少 HTTP 请求次数;
  • 节省带宽流量;
  • js 压缩把代码混淆后可看性降低,带来一定安全性;

1. 安装Grunt

Grunt 是运行在 Node.js 平台上,先要 安装 Node.js, 然后 安装 Grunt

npm install -g grunt-cli

2. 使用Grunt

两个关键的配置文件:

  • Gruntfile.js 是用来配置和定义任务并加载Grunt插件;
  • package.json 是 npm 用来配置项目的元数据,如配置文件合并与压缩依赖的插件;
我们的 DEMO 项目Gruntfile.js 配置文件:

'use strict'; module.exports = function(grunt) { // 项目配置
grunt.initConfig({
// 加载元数据
pkg: grunt.file.readJSON('package.json'),
banner: '/*! <%= pkg.name %> - v<%= pkg.version %> - ' +
'<%= grunt.template.today("yyyy-mm-dd") %>*/\n',
// 合并任务配置
concat: {
options: {
banner: '<%= banner %>',
stripBanners: true,
},
css: {
// 源文件,数组,
src: ['src/css/test1.css', 'src/css/test2.css'],
// 目标文件, pkg.name 是定义在 package.json 文件中的 name
dest: 'dest/<%= pkg.name %>.css'
},
js: {
options: {
// js 文件合并用 ';'分隔
separator: ';',
},
src: ['src/js/test1.js', 'src/js/test2.js'],
dest: 'dest/<%= pkg.name %>.js'
},
},
// 压缩 css 文件
cssmin: {
css: {
src: 'dest/<%= pkg.name %>.css',
dest: 'dest/<%= pkg.name %>-min.css'
}
},
// 压缩 js 文件
uglify: {
js: {
src: 'dest/<%= pkg.name %>.js',
dest: 'dest/<%= pkg.name %>.min.js'
},
},
}); // These plugins provide necessary tasks.
grunt.loadNpmTasks('grunt-contrib-concat');
grunt.loadNpmTasks('grunt-contrib-uglify');
grunt.loadNpmTasks('grunt-css');
// 指定默认任务.
grunt.registerTask('default', ['concat','cssmin','uglify']);
};

每个配置的作用和意义,请看上面的注释,应该很清晰了,注意的是任务的命名不能改: concat, cssmin,uglify, 否则不识别;

package.json 配置
{
"name": "all",
"description": "js,css 文件合并与压缩",
"version": "0.1.0",
"homepage": "https://git.oschina.net/grissom/grunt_demo.git",
"author": "Grissom",
"repository": {
"type": "git",
"url": "https://git.oschina.net/grissom/grunt_demo.git"
},
"engines": {
"node": ">= 0.10.0"
},
"devDependencies": {
"grunt-contrib-concat": "~0.3.0",
"grunt-contrib-uglify": "~0.2.0",
"grunt": "~0.4.5",
"grunt-css": ">0.0.0"
},
"keywords": []
}

3. 执行Grunt

  • 打开 Node.js 的命令行窗口;
  • 进入到项目的路径;
  • 安装依赖插件, 执行 npm install 命令;
  • 执行合并与压缩任务 grunt 命令;

Demo 源码

开箱即用 - Grunt合并和压缩 js,css 文件的更多相关文章

  1. MVC打包压缩JS&CSS文件调试时过滤了一些文件

    BundleTable.这个确实是比较好用,打包并压缩了CSS,使之加载时减少流量. 但是在调试的时候会疑问为何有很多JS,CSS文件无法打包,其实是因为调试时VS自动过滤了如下文件:   后台跟踪了 ...

  2. gulp入门-压缩js/css文件(windows)

    类似于grunt,都是基于Node.js的前端构建工具.不过gulp压缩效率更高. 工具/原料 nodejs/npm 方法/步骤 首先要确保pc上装有node,然后在global环境和项目文件中都in ...

  3. IIS7.5打开GZip压缩,同时启用GZip压缩JS/CSS文件的设置方法[bubuko.com]

    IIS7.5或者IIS7.0开启GZip压缩方法:打开IIS,在右侧点击某个网站,在功能视图中的“IIS”区域,双击进入“压缩”,如图下图: 分别勾选“启用动态内容压缩”和“启用静态内容压缩”.这样最 ...

  4. Web网站配置Gzip,压缩js css文件

    启用apache的gzip 找到httpd.conf,打开文件找到对mod_deflate的注释 #LoadModule deflate_module modules/mod_deflate.so 去 ...

  5. 用GruntJS合并、压缩JS文件

    为什么要合并.压缩你的JS文件?        一个项目开发完成我们总能发现有一堆js文件非常混乱.           一般在一个HTML文档加载的时候,浏览器会根据HTML代码从上到下读取所需要加 ...

  6. ASP.NET MVC 4 Optimization的JS/CSS文件动态合并及压缩

    JS/CSS文件的打包合并(Bundling)及压缩(Minification)是指将多个JS或CSS文件打包合并成一个文件,并在网站发布之后进行压缩,从而减少HTTP请求次数,提高网络加载速度和页面 ...

  7. JS&CSS文件请求合并及压缩处理研究(五)

    接上篇.在我们最终调用 @Html.RenderResFile(ResourceType.Script) 或者 @Html.RenderResFile(ResourceType.StyleSheet) ...

  8. java Web程序使用wro4j合并、压缩js、css等静态资源

    在Web项目中,js.css合并压缩,不仅有利于减少Http请求数量.减少宽带资源占用,还能有效的管理各种js.css的引入,使整个项目更加有序.而对于访问用户来说,其更大的好处是增加了页面的打开速度 ...

  9. 前端js,css文件合并三种方式,bat命令

    前端js,css文件合并三种方式,bat命令 前端js文件该如何合并三个方式如下:1. 一个大文件,所有js合并成一个大文件,所有页面都引用它.2. 各个页面大文件,各自页面合并生成自己所需js的大文 ...

随机推荐

  1. javascript 对象的复制

    1. jQuery has a method that can be used to deep-clone objects, the$.extend() function. Let’s take a ...

  2. Bessie Goes Moo

    Bessie Goes Moo 题目描述 Farmer John and Bessie the cow love to exchange math puzzles in their free time ...

  3. Sublime Text 3 搭建 Golang 开发环境

    安装Golang go语言主页: https://golang.org/ go语言安装下载: https://golang.org/dl 环境变量设置: GOROOT: GOROOT变量设置go安装的 ...

  4. C#代码发送邮件

    本次测试的邮箱为163邮箱 1.首相对邮箱进行一些设置(详见下图):打开设置选取客户端授权密码项,开启设置:以后在客户端登录时将使用刚刚设置的密码! 2.上干货 public static void ...

  5. git 与 github基本使用

    这里只对git 与 github的基本使用介绍,对于简单的步骤不做详细的说明,可以在网上搜索 一.git与github的安装与链接 1.git 安装:百度搜索"git",下载安装即 ...

  6. ssh密钥登录及远程执行命令

    以192.168.1.104作为客户机 以192.168.1.103作为服务器 使用密钥登录 创建密钥对 在SSH客户机创建用户秘钥对 ssh-keygen -t rsa 之后全回车即可 将会在~/. ...

  7. A tutorial that will show you how to build an instant messaging app with Sinch.

    http://stackoverflow.com/questions/26247986/unsatisfiedlinkerror-couldnt-load-sinch-android-rtc-from ...

  8. lvs(+keepalived)、haproxy(+heartbeat)、nginx 负载均衡的比较分析

    目前使用比较多的就是标题中提到的这两者,其实lvs和haproxy都是实现的负载均衡的作用,keepalived和heartbeat都是提高高可用性的,避免单点故障.那么他们为什么这么搭配,而又有什么 ...

  9. 7、手把手教你Extjs5(七)自定义菜单1

    顶部和底部区域已经作好,在顶部区域有一个菜单的按钮,这一节我们设计一个菜单的数据结构,使其可以展示出不同样式的菜单.由于准备搭建的是一个系统模块自定义的系统,因此菜单也是自定义的,在操作员系统登录的时 ...

  10. JavaScript 事件模型 事件处理机制

    什么是事件? 事件(Event)是JavaScript应用跳动的心脏 ,也是把所有东西粘在一起的胶水.当我们与浏览器中 Web 页面进行某些类型的交互时,事件就发生了.事件可能是用户在某些内容上的点击 ...