最简单的前端自动化套件gulp + browserSync

大前端时代的到来,让我们对未来充满了各种幻想和憧憬,同时也带给我们了痛苦与迷茫。各种框架漫天飞,各种打包工具到处跑;

牛逼哄哄的大神们,一言不合就开始自己打造神器。我觉得你的框架怎么怎么不好,我觉得你这里封装的怎么怎么稀烂,于是乎,五环之外回龙观中,闭关修炼九九八十一天.......

像我们这样的搬砖小民工,尚浅的道行还不足以打造神器,那我们就一起静下心来好好钻研一下别人的神器,不会造还不会用吗!!!

现在都崇尚前端自动化,那就要知道前端构建工具——实现前端代码的编译(sass、less)、压缩、测试;图片的压缩以及浏览器自动刷新等等功能。目前流行的三大前端构建工具 grunt 、 gulp 、 fis3 、、、、

哎,废话也真多!下面进入正题,运用gulp + browserSync来实现前端自动化,这可是我的处女贴哦...

安装gulp就不用多说了吧!新建package.json文件,把下面配置文件拷贝进去

{

"name": "amujoe",

"version": "1.0.0",

"description": "",

"main": "gulpfile.js",

"scripts": {

"test": "echo \"Error: no test specified\" && exit 1"

},

"author": "joe",

"license": "ISC",

"devDependencies": {

"browser-sync": "^2.17.5",

"gulp": "^3.9.1",

"gulp-concat": "^2.6.0",

"gulp-less": "^3.2.0",

"gulp-minify-css": "^1.2.4",

"gulp-notify": "^2.2.0",

"gulp-plumber": "^1.1.0",

"gulp-uglify": "^2.0.0"

}

}

npm 安装依赖

npm install

安装依赖需要一段时间,这时候我们完成另一个配置文件:gulpfile.js;小哥已经把备注标注的很清楚了

var gulp = require('gulp'),

browserSync = require('browser-sync').create(),//实时更新

less = require('gulp-less'),//less

cssmin = require('gulp-minify-css'),//压缩css

uglify = require('gulp-uglify'),// 压缩js

concat = require('gulp-concat'),//合并文件

notify = require('gulp-notify'),//处理崩溃问题

plumber = require('gulp-plumber');//报错 不中断当前任务

//less

gulp.task('less',function(){

console.log('less');

gulp.src('./src/less/*.less')

.pipe(plumber({

errorhandler:notify.onError('Error:<% error.message %>')

}))//报错

.pipe(less())//没错 就编译

.pipe(concat('main.css'))

.pipe(gulp.dest('./src/css'));//编译生成文件夹

//console.log('less');

});

gulp.task('cssmin',function(){

console.log('cssmin');

gulp.src('./src/css/*.css')

.pipe(cssmin({

advanced: false,//类型:Boolean 默认:true [是否开启高级优化(合并选择器等)]

compatibility: 'ie7',//保留ie7及以下兼容写法 类型:String 默认:''or'*' [启用兼容模式; 'ie7':IE7兼容模式,'ie8':IE8兼容模式,'*':IE9+兼容模式]

keepBreaks: false,//类型:Boolean 默认:false [是否保留换行]

keepSpecialComments: '*'

//保留所有特殊前缀 当你用autoprefixer生成的浏览器前缀,如果不加这个参数,有可能将会删除你的部分前缀

}))

.pipe(gulp.dest('./dist/css'));//编译生成文件夹

 })

//js

gulp.task('jsmin',function(){

console.log('jsmin-a');

gulp.src('./src/js/*.js')

.pipe(uglify())

.pipe(gulp.dest('./dist/js'));

console.log('jsmin-b');

 })

//watch less

gulp.task('watch',function(){

gulp.watch('./src/less/*.less',['less']);

 })

//watch css

gulp.task('watchcss',function(){

gulp.watch('./src/css/*.css',['cssmin']);

 })

///watch js

gulp.task('watchjs',function(){

gulp.watch('./src/js/*.js',['jsmin']);

 })

///browserSync 启动一个静态服务器

gulp.task('server',function(){

  browserSync.init({

files:'**',

server:{

baseDir:'./'

}

 })

 })

//default 默认的任务

gulp.task('taskList',['server','watch','watchjs','watchcss']);

gulp.task('default',function(){

gulp.start('taskList');

console.log('go start');

 })

我的文件目录是下面这样的;src 是开发环境,lib是共用插件,dist是生产环境


完成以上配置以后,运行gulp就可以专心搬砖了

gulp

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容

  • gulpjs是一个前端构建工具,与gruntjs相比,gulpjs无需写一大堆繁杂的配置参数,API也非常简单,学...
    小裁缝sun阅读 924评论 0 3
  • gulpjs是一个前端构建工具,与gruntjs相比,gulpjs无需写一大堆繁杂的配置参数,API也非常简单,学...
    依依玖玥阅读 3,150评论 7 55
  • 对网站资源进行优化,并使用不同浏览器测试并不是网站设计过程中最有意思的部分,但是这个过程中的很多重复的任务能够使用...
    懵逼js阅读 1,061评论 0 8
  • 编辑于2015年 转载自某作者的译文 作者要是看到请联系我注明出处 对网站资源进行优化,并使用不同浏览器测试并不是...
    krock01阅读 447评论 0 2
  • gulp作为前端构建项目的一个工具,自己理解gulp主要方面的作用:1.构建本地服务器。2.快速构建项目。3.对代...
    张宪宇阅读 1,150评论 0 2