gulp入坑系列(2)——初试JS代码合并与压缩

在上一篇里成功安装了gulp到项目中,现在来测试一下gulp的合并与压缩功能

gulp入坑系列(1)——安装gulp(传送门):http://www.cnblogs.com/YuuyaRin/p/6159809.html

在之前建立的项目中写入,在根目录新建js文件夹,并在文件夹中新建两个js文件,代码如下:

index.js:

  1. var index={};
  2. index={
  3. test:function(argument){
  4. console.log(‘test‘);
  5. }
  6. }
  7. index.test();

main.js:

  1. var main = {};
  2. main.test=function(argument){
  3. console.log("main test");
  4. }
  5. main.test();

在根目录新建文件夹build,并在build里新建一个空的js文件:all.min.js

在根目录下新建index.html ,在其中引用build下的all.min.js。

index.html:

  1. <script type="text/javascript" src="build/all.min.js"></script>

接下来编辑gulpfile.js文件,来告诉gulp我们要把index.js,main.js合并起来压缩再写入all.min.js中

gulpfile.js:

  1. var gulp = require(‘gulp‘);//gulp自身
  2. var uglify= require(‘gulp-uglify‘);//<span style="font-family: Arial, Helvetica, sans-serif;">引入压缩组件</span>
  3. var concat = require(‘gulp-concat‘);//<span style="font-family: Arial, Helvetica, sans-serif;">引入合并组建</span>
  4. var paths = {
  5. scripts:[‘js/index.js‘,‘js/main.js‘]
  6. } //定义要操作的文件路径
  7. gulp.task(‘default‘, function() {
  8. gulp.src(paths.script)//找到项目下paths变量所定义的script文件
  9. .pipe(uglify())//压缩
  10. .pipe(concat(‘all.min.js‘))//输入到all.min.js中
  11. .pipe(gulp.dest(‘build‘));//指定目录
  12. });

tips:gulp的执行流程采用了流式操作,每一个pipe()可以理解成,上一个操作的输出,就是下一个操作的输入,比如uglify()压缩后输出的,就是concat要输入到文件中的,而concat输出的文件,是gulp.dest要加入的目录中的,可以理解成每部操作都return了下一步要使用的东西。

最终目录结构如下:

接下来就可以在命令行工具中cd到项目的根目录中执行gulp指令了。

此时也许会出现 Cannot find module ‘gulp-uglify‘这样的报错,是因为gulpfile所require的gulp-uglify和gulp-concat插件并不存在,所以可以利用npm在项目中装入即可:

npm install --save-dev gulp-uglify    回车

npm install --save-dev gulp-concat   回车

 

安装完成后再次执行gulp指令,成功后,可以查看一下我们原本空的all.min.js文件,可以看到main.js和index.js已经在all.min.js中压缩合并了

  1. var index={};index={test:function(e){console.log("test")}},index.test();
  2. var main={};main.test=function(n){console.log("main test")},main.test();

然后运行一下我们的index.html,打开浏览器控制台,会发现两个js的内容成功输出:

说明gulp成功执行了JS文件的合并与压缩的操作。

时间: 2024-08-25 12:05:02

gulp入坑系列(2)——初试JS代码合并与压缩的相关文章

gulp入坑系列(3)——创建多个gulp.task

继续gulp的爬坑路,在准备get更多gulp的具体操作之前,先来明确一下在gulp中创建和使用多个task任务的情况. gulp所要做的操作都写在gulp.task()中,系统有一个默认的default任务,如下: var gulp = require('gulp');//gulp自身 gulp.task('default',['task1','task2'], function() { // 将你的默认的任务代码放在这 console.log("default"); }); 在命令

js代码美化、压缩、解压方法

js代码在线美化.压缩.解压网站:js.clicki.cc     http://tool.chinaz.com/js.aspx    http://tool.oschina.net/jscompress js的下载速度快,就需要尽量减小js文件的大小,两种Js压缩工具(Javascript压缩工具):Javascript compressed - YUI Compressor和Javascript compressed - ESC Introduction 这里的Javascript压缩,都是

1-STM32带你入坑系列(STM32介绍)

由于自己的物联网开发板上的单片机是用的STM32,但是有些朋友没有用过,所以我将用这块开发板,带着大家入门STM32 先介绍一下STM32,我是在大三下学期的时候开始接触STM32,当时是想做一个小车,要用摄像头,所以学习了STM32. 大家可以看我的这一系列的文章  https://www.cnblogs.com/yangfengwu/category/802676.html 说一下哈,如果学单片机的,最好要学习一下STM32,因为现在大部分公司都在用,或者这个系列的,或者都是Cortex-M

Swift入坑系列—集合类型

数组(Arrays) 字典(Dictionaries) 数组(Arrays) 在OC里面,NSArray和NSMutableArray这两个类可以存储任意类型的对象,并且不提供所返回对象的任何特别信息.在Swift中,数据值被存入某个数组之前类型必须明确.方法是通过显式的类型标注或者类型推断,而且不是必须是class类型. //定义了一个存储 字符串类型 的可变数组('var'字段修饰) var shoppingList: [String] = ["Eggs", "Milk&

VUE 入坑系列 一 事件

html代码 <div id="app"> <button v-on:click="counter += 1">加1</button> <button @click="counter += 1">加2</button> <button v-on:click="minusOne">减1</button> <button @click=&qu

VUE 入坑系列 一 双向绑定

html代码 <div id="app"> <p>{{message}}</p> <span>message1</span> <input v-model="message"> <span>message2</span> <input v-model="message"> </div> javascript代码 var vm =

如何应用r.js对requirejs下的js代码合并

1.在根目录新建build.js ({ baseUrl:'js', paths:{ jquery:'static/jquery-1.10.2.min', underscore:'static/underscore', bootstrap:'static/bootstrap' }, shim:{ 'bootstrap':['jquery'] }, name:'main', out:'js/main-build.js' }) 2.cmd下找到项目所在目录 执行 node r.js -o build.

web前端入坑第五篇:秒懂Vuejs、Angular、React原理和前端发展历史

秒懂Vuejs.Angular.React原理和前端发展历史 2017-04-07 小北哥哥 前端你别闹 今天来说说 "前端发展历史和框架" 「前端程序发展的历史」 「 不学自知,不问自晓,古今行事,未之有也 」 我们都知道如今流行的框架:Vue.Js.AngularJs.ReactJs.已经逐渐应用到各个项目和实际应用中,它们都是MVVM数据驱动框架系列的一种. 在了解MVVM之前,我们先回想一下前端发展的历史阶段,做到心中有数,才会更好理解. 这段回想历史.由于网上就可查不少资料,

web前端入坑第四篇:你还在用 jQuery?

web前端入坑第四篇:你还在用 jQuery? 大妈都这么努力,我们有几个人回家还看书的? 先来补齐[web前端入坑系列]前三篇的连接web前端入坑系列:点击标题进入第一篇: web 前端入坑第一篇:web前端到底是什么?有前途吗第二篇: web前端入坑第二篇:web前端到底怎么学?干货资料!第三篇:web前端入坑第三篇 | 一条"不归路" - 学习路线! 再说这个话题之前,我们先来扫盲普及一下 [jquery] 到底是什么以及它火爆将近十年的重要原因. [ 重新认识 - Jquery