Grunt插件之uglify--js代码压缩与合并

2024-05-31 04:48

本文主要是介绍Grunt插件之uglify--js代码压缩与合并,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

      平时在开发项目的时候,都是在本地测试,加载代码都是走localhost,页面刷新基本是秒出,所以没有考虑js文件的大小。最近项目上线,部署到了服务器上之后,测试的时候发现加载速度特别慢,一查看网络,发现有的js文件加载时间居然超过1s。没办法,把代码压缩看看。果然压缩好之后加载快了很多。而将代码压缩和混淆之后,也能提高网站的安全性。

下面是使用grunt的uglify插件的安装和使用:

前提:安装了nodejs
环境:window linux iOS 通用

首先安装grunt-cli,即grunt的命令行工具,安装好之后,会将其添加到系统环境里,在系统上的任何地方都能使用grunt命令。

使用npm安装grunt-cli, nodejs自带npm包管理工具, 安装好nodejs之后,npm也就安装上了。
在系统的任何地方执行下面的命令:

npm install -g grunt-cli

安装了grunt-cli之后并不等于安装了grunt,因为grunt是随工程安装的,这样的话,可以创建多个grunt工程,在各自的工程下安装grunt工具。想要运行某一工程的话,只需要在其工程目录下运行grunt命令即可。

创建grunt项目,并安装uglify插件。

在任意目录下执行命令安装grunt和uglify插件,执行命令(本例在uglify目录下):

npm install --save grunt grunt-contrib-uglify

安装好之后,目录下回出现node_modules子目录,里面是node模块的安装位置,grunt和uglify就被安装在里面。

初始化项目:

在uglify目录下创建空文件Gruntfile.js。
在uglify目录下执行命令:

npm init

如果没有必要的修改,就一路回车,最后输入yes。初始化项目完成之后,uglify目录下会出现package.json文件,这个文件保存了项目的基本信息和入口文件等。

现在我们来编辑项目的入口文件Gruntfile.js文件。也就是package.json的main字段指定的文件,这两者必须一致。

将以下代码复制到Gruntfile.js 里:

module.exports = function (grunt) { grunt.initConfig({  uglify: {                //制定插件的名字build: {              //制定任务的名字 options: {mangle: false   //默认混淆变量名和函数名},files: [{//将数组中的文件合并 并且压缩到combine文件里'dist/combine.js':['src/a.js','src/b.js','src/c.js','src/d.js']}]}  }  }); grunt.loadNpmTasks('grunt-contrib-uglify'); //加载插件 
})

运行工程:

grunt uglify

这样的话,执行uglify下的所有任务(如包含多个任务的话),如果想只运行某一个任务的话,可以这样执行:

grunt uglify:build  

这样的话就只会执行uglify下的build这个任务。

上面是代码压缩的最基本的配置,下面是更多的配置,包括:
1、代码混淆的规则
2、非ascii码的处理规则
3、压缩文件的注释
4、压缩文件的格式控制
5、批量压缩的配置
6、生成sourcemap文件
7、对IE浏览器的兼容性设置
8、更多的demo请移步github

1、代码混淆的规则

module.exports = function (grunt) { grunt.initConfig({  uglify: {                //制定插件的名字build: {  //这个任务的名字叫做buildoptions :{mangle : false   //不混淆函数名和变量名 默认会混淆},files: [{      'dist/uncombineAndMangle.js':['src/b.js'] //合并压缩}]}},compress_mangle_except: {files: {'dist/compress_mangle_except.js': ['src/b.js']},options: {mangle: {except: ['dom','JQuery']  //不混淆该数组中的变量名}}},compress_mangle_beautify: {files: {'dist/compress_mangle_beautify.js': ['src/b.js']},options: {beautify: true,    //混淆但不压缩文件 footer: '\n// This is a footer.'          //在压缩文件底部加上注释}},}); grunt.loadNpmTasks('grunt-contrib-uglify'); //加载插件 
})

运行所有任务

grunt uglify

运行单个任务

grunt uglify:build
grunt uglify:compress_mangle_except
grunt uglify:compress_mangle_except
...

2、非ascii码的处理规则

module.exports = function (grunt) { grunt.initConfig({  uglify: {       ASCIIOnly: {src: 'src/b.js',dest: 'dist/asciionly.js',options: {mangle: false,ASCIIOnly: true   //允许将非ascii字符编码成\uxxx格式(unicode编码)汉字会被编码}},}})grunt.loadNpmTasks('grunt-contrib-uglify'); //加载插件 
}

执行任务

grunt uglify:ASCIIOnly

3、压缩文件的注释

module.exports = function (grunt) { grunt.initConfig({  uglify: {       comments: {src: 'src/b.js',dest: 'dist/comments.js',options: {mangle: false,preserveComments: 'some',  //保留哪些注释  可选false all some Functionfooter: '\n// This is a footer.'          //在压缩文件底部加上注释}}}})grunt.loadNpmTasks('grunt-contrib-uglify'); //加载插件 
}

4、压缩文件的格式控制

module.exports = function (grunt) { grunt.initConfig({  uglify: {       maxLineLen: {src: 'src/b.js',dest: 'dist/maxLineLen.js',options: {mangle: false,maxLineLen: 1000   //设置压缩文件每行的字符长度}},exportAll: {src: 'src/b.js',dest: 'dist/exportAll.js',options: {mangle: false,                    wrap: 'testExport',         //封裝成閉包,将全局变量挂载到testExport下 然后暴露出来exportAll: true             //将函数封装成闭包之后,暴露所有全局变量}},}})grunt.loadNpmTasks('grunt-contrib-uglify'); //加载插件 
}

5、批量压缩的配置

module.exports = function (grunt) { grunt.initConfig({  uglify: {       batch: {expand : true,            //将占位符*展开 即使用占位符匹配文件名src: 'src/**/*.js',       //压缩src目录及所有子目录下的js文件dest: 'dist',             //压缩文件存放到dist目录下的同名目录ext: '.min.js',           //压缩文件的后缀名},}})grunt.loadNpmTasks('grunt-contrib-uglify'); //加载插件 
}

6、生成sourcemap文件

module.exports = function (grunt) { grunt.initConfig({  uglify: {       sourcemap_basic: {src: 'src/b.js',dest: 'dist/sourcemap_basic.js',options: {sourceMap: true,     //压缩的同时  产生sourcemap 默认保存在压缩文件的同一目录sourceMapName: 'dist/source_map_custom_name'  //指定sourcemap的文件名 不指定则以压缩文件名+.map为文件名}},sourcemap_multipleFunctionNames: {src: 'src/*.js',dest: 'dist/',expand:true,  options: {sourceMap: true,             //压缩的同时  产生 sourcemapsourceMapRoot : 'dist/maps/', //指定source的根目录sourceMapName: function(dist){    //用函数计算出sorurcemap的文件名return dist + ".func.min.js.map"}}},}})grunt.loadNpmTasks('grunt-contrib-uglify'); //加载插件 
}

7、对IE浏览器的兼容性设置

module.exports = function (grunt) { grunt.initConfig({  uglify: {       screwIE8: {src: 'src/b.js',dest: 'dist/screwIE8.js',options: {screwIE8: false          //是否兼容ie8及以下}},}})grunt.loadNpmTasks('grunt-contrib-uglify'); //加载插件 
}

这篇关于Grunt插件之uglify--js代码压缩与合并的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1017403

相关文章

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例