gulp 项目的构建模板,gulp 常用插件的配置合集,适合日常小型多页面项目的开发,功能上近似腾讯的 tmt-workflow,但更简单并便于修改。
- 监听文件变动,自动刷新浏览器 (LiveReload)
- 合成 CSS Sprite 雪碧图,并输出响应式 css (size 使用 rem,position 使用百分比)
- artTemplate 风格模板,支持预编译、include、简洁语法
- 识别合并依赖文件,输出去缓存文件 Reversion (MD5),自动插入 HTML
- Less -> CSS
- CSS Autoprefixer 前缀自动补全
- CSS 压缩 cssnano
- JS 合并压缩
- HTML 压缩
- imagemin 图片压缩
- 一键打包
下载或克隆本项目,进入根目录执行: npm install
。
国内通过可使用淘宝的 npm 镜像 cnpm,速度会提升很多。
执行 gulp watch
后会发生以下过程:
- 编译合并部分文件:
- artTemplate -> template.js
- 合并libs -> lib.js
- sprite 图合成 -> sprite.less
- less -> css
- 自动监听文件改动,触发浏览器刷新
开发完成后,执行 gulp build
生成最终文件到 /dist 目录,包含以下过程:
- 文件转移
- 图片压缩
- CSS/JS/IMG/HTML 压缩合并
- 文件添加 MD5 版本号
有一些任务可单独使用,可在 gulpfile.js
中具体查看,包括:
gulp less
编译 main.less 文件,添加前缀并压缩,配置请参考 gulp-less、gulp-autoprefixer、gulp-cssnano
gulp sprite
合并雪碧图并输出 sprite.less,可直接使用
.spritesheet(@图片名)
在 less 文件中调用每个图片,配置请参考 gulp.spritesmith
gulp tpl
编译合并 template 文件,并输出 template.js,配置请参考 artTemplate、tmodjs
├── gulpfile.js // gulp 任务配置文件
│
├── less.sprite.template.mustache // gulp.spritesmith 的模板文件
│
└──project // 项目文件夹
├── src // 开发目录,`gulp watch` 阶段会监听此目录下的部分文件变动
│ ├── css // 存放 Less 文件的目录,只有 main.less 会被编译
│ │ ├── modules // less 模块文件夹,包含 reset.less 、 variable.less 等
│ │ ├── main.less // CSS 编译出口文件
│ │ └── sprite.less // 雪碧图合并输出的 less 文件,将被 main.less 引用
│ │
│ ├── fonts
│ ├── images
│ ├── js
│ │ ├── lib // js 类库文件夹,会合并输出 lib.js
│ │ ├── base.js
│ │ └── a.js, b.js, c.js
│ │
│ ├── media
│ ├── slice // 切片图片素材,将会进行雪碧图合并
│ ├── sprite // 雪碧图图合并后的输出文件夹
│ ├── tpl // 网页 template 模板文件夹
│ │ ├── build // 合并编译好的模板会放入这个文件夹
│ │ ├── public // 公用模板文件夹,可通过 include 引用
│ │ ├── tpl1.html
│ │ └── tpl2.html
│ │
│ ├── a.html
│ ├── b.html
│ └── c.html
│
└── dist // 生产目录,由 `gulp build` 任务生成