gulp(gulpfile.js)配置文件

1 /*
 2 参考代码网址:
 3 http://www.ido321.com/1622.html           
 4 http://colobu.com/2014/11/17/gulp-plugins-introduction/#gulp-rename            
 5 https://github.com/nimojs/gulp-book  
 6  */
 7 // 获取 gulp
 8 var gulp = require('gulp'),
 9     // js 压缩插件 (用于压缩 JS)
 10     uglify = require('gulp-uglify'),
 11     // 压缩css插件(cssnano将取代gulp-minify-css)
 12     minifyCSS = require('gulp-minify-css'),
 13     cssnano = require('gulp-cssnano'),
 14     // 获取 gulp-imagemin 模块
 15     imagemin = require('gulp-imagemin'),
 16     // 重命名 插件
 17     rename = require('gulp-rename'),
 18     // 压缩html插件
 19     htmlmin = require('gulp-htmlmin'),
 20     // 合并文件
 21     concat = require("gulp-concat"),
 22     // html 文件对合并文件后的替换处理插件
 23     htmlReplace = require("gulp-html-replace"),
 24     // 复制文件(文件拷贝)
 25     copy = require('copy'),
        //webserver服务      
        webserver = require('gulp-webserver');

 27 // 版本号
 28 var APP_VERSION = 'v.1.0';
 29
// 开启服务

    gulp.src('./')
      .pipe(webserver({
        port: 8880,//端口
        host: 'localhost',//域名
        liveload: true,//实时刷新代码。不用f5刷新
        directoryListing: {
          path: './index.html', //要打开的文件
          enable: true
        }
      }))
    });

 30 
 31 // 压缩 js 文件
 32 // 在命令行使用 gulp script 启动此任务
 33 gulp.task('script', function() {
 34     // 1\. 找到文件
 35     gulp.src('js/*.js')
 36     // 2\. 压缩文件
 37         .pipe(uglify())
 38     // new: 压缩前修改压缩后新文件名字
 39         .pipe(rename( function(path){
 40           path.basename += "_" + APP_VERSION; 
 41         } ) )
 42     // 3\. 另存压缩后的文件
 43         .pipe(gulp.dest('dist/js'))
 44 });
 45 
 46 // 压缩 css 文件
 47 // 在命令行使用 gulp css 启动此任务
 48 gulp.task('css', function () { 
 49     // 1\. 找到文件
 50     gulp.src('css/*.css')
 51     // 2\. 压缩文件
 52         .pipe(minifyCSS())
 53     // 3\. 另存为压缩文件
 54         .pipe(gulp.dest('dist/css'))
 55 });
 56 
 57 // 压缩图片任务
 58 // 在命令行输入 gulp images 启动此任务
 59 gulp.task('images', function () { 
 60     // 1\. 找到图片
 61     gulp.src('images/*.*')
 62     // 2\. 压缩图片
 63         .pipe(imagemin({
 64             progressive: true
 65         }))
 66     // 3\. 另存图片
 67         .pipe(gulp.dest('dist/images'))
 68 });
 69 
 70 // 合并js 任务(合并压缩成功后的 js文件)
 71 gulp.task('concat', function () { 
 72       gulp.src('dist/js/*.js')  //要合并的文件
 73     .pipe( concat('all.js') )  // 合并匹配到的js文件并命名为 "all.js"
 74     .pipe( gulp.dest('dist/js') );
 75 });
 76 
 77 // 解决 gulp 合并文件后, html调用代码对应替换
 78 gulp.task('htmlreplace', function(){
 79       gulp.src('canvas_test.html')
 80       .pipe( htmlReplace({'js': 'js/all.js'}) )
 81       .pipe( gulp.dest('dist/') );
 82 });
 83 // 压缩html 任务
 84 gulp.task('htmlmin', function () { 
 85     var options = { 
 86         collapseWhitespace: true,//压缩HTML
 87         //省略布尔属性的值 <input checked="true"/> ==> <input />
 88         collapseBooleanAttributes: false,
 89         //删除所有空格作属性值 <input id="" /> ==> <input />
 90         removeEmptyAttributes: true,
 91         //删除<script>的type="text/javascript"
 92         removeScriptTypeAttributes: true,
 93         //删除<style>和<link>的type="text/css"
 94         removeStyleLinkTypeAttributes: true,
 95         minifyJS: true,//压缩页面JS
 96         minifyCSS: true//压缩页面CSS
 97     };
 98       gulp.src('*.html')
 99         .pipe(htmlmin(options)) 
100         .pipe(gulp.dest('dist')); 
101 }); 
102 
103 // 清除文件任务
104 gulp.task('clean', function(cb){ 
105    del(['dist/*']); 
106     cb(); 
107 }); 
108 
109 // 复制任务(连续复制多个文件时,最好加上回调函数)
110 gulp.task('copy', function(cb){ 
111     copy(['copy_file2.txt', 'copy_file.txt'], 'dist/'); 
112     cb(); 
113 }); 
114 
115 
116 /************************************************************* 
117 *                         组合任务 
118  ************************************************************/
119 
120 // js 压缩合并任务
121 gulp.task('ugconjs', function(){ 
122     // 1\. 找到文件
123       gulp.src(['js/concat_base.js', 'js/uglify_utils.js']) 
124     // 2\. 压缩文件
125         .pipe(uglify()) 
126     // 3\. 合并成一个文件
127         .pipe( concat('all.js') ) 
128     // 4\. 改名
129         .pipe(rename( function(path){ 
130           path.basename += "_" + APP_VERSION; 
131 } ) )
132     // 5\. 另存压缩后的文件
133         .pipe(gulp.dest('dist/js')) 
134 }); 
135 
136 // 组合任务: 先替换html再压缩
137 gulp.task('htmlcomp', function(){ 
138   var options = { 
139     collapseWhitespace: true,//压缩HTML
140     //省略布尔属性的值 <input checked="true"/> ==> <input />
141     collapseBooleanAttributes: false, 
142     //删除所有空格作属性值 <input id="" /> ==> <input />
143     removeEmptyAttributes: true, 
144     //删除<script>的type="text/javascript"
145     removeScriptTypeAttributes: true, 
146     //删除<style>和<link>的type="text/css"
147     removeStyleLinkTypeAttributes: true,
148     minifyJS: true,//压缩页面JS
149     minifyCSS: true//压缩页面CSS
150 }; 
151   gulp.src('canvas_test.html') 
152       .pipe( htmlReplace({'js': 'js/all_' + APP_VERSION + '.js'}) ) 153 .pipe( htmlmin(options) ) 
154       .pipe( gulp.dest('dist/') ); 
155 }); 
156 
157 // 默认任务
158 gulp.task('default', ['clean'], function(){ 
159     gulp.start('ugconjs', 'htmlcomp', 'copy', 'css', 'images'); 
160 }); 
161 
162 /************************************************************* 
163                   本地js  html css本地压缩 
164  ************************************************************/
165 // 字符串拷贝进 js/str.js 中, 然后运行 `gulp str-js`
166 gulp.task('str-js', function() { 
167     gulp.src('js/str.js') 
168     .pipe(uglify()) 
169    pipe(gulp.dest('dist/js')); 
170 }); 
171 // 字符串拷贝进 css/str.css 中, 然后运行 `gulp str-css`
172 gulp.task('str-css', function () { 
173     gulp.src('css/str.css') 
174    .pipe(cssnano()) 
175    .pipe(gulp.dest('dist/css')); 
176 }); 
177 // 字符串拷贝进 str.html 中, 然后运行 `gulp str-html`
178 gulp.task('str-html', function () { 
179     var options = { 
180         collapseWhitespace: true,//压缩HTML
181         //省略布尔属性的值 <input checked="true"/> ==> <input />
182         collapseBooleanAttributes: false, 
183         //删除所有空格作属性值 <input id="" /> ==> <input />
184         removeEmptyAttributes: true, 
185         //删除<script>的type="text/javascript"
186         removeScriptTypeAttributes: true, 
187         //删除<style>和<link>的type="text/css"
188         removeStyleLinkTypeAttributes: true, 
189         minifyJS: true,//压缩页面JS
190         minifyCSS: true//压缩页面CSS
191 }; 
192       gulp.src('str.html') 
193       .pipe(htmlmin(options)) 
194        .pipe(gulp.dest('dist')); 195 });
         });
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容