在上一篇 前端构建大法 Gulp 系列 (一):为什么需要前端构建 中,我们说了为什么需要前端构建,简单一句话,就是让我们的工作更有效率。
相信熟悉前端的人对Grunt一定不陌生,实际上我自己之前的很多项目也是在用Grunt, Grunt的出现是前端开发者的福音,大大减少了前端之前很多手工工作的繁琐以及我上一篇 前端构建大法 Gulp 系列 (一):为什么需要前端构建 提到的那些问题。
那么既然Grunt可以做到几乎所有的事情,那么为什么我们需要Gulp呢?
data:image/s3,"s3://crabby-images/82532/825323cd75e41ba75df21453c06505e6437b6125" alt=""
Grunt与Gulp的区别
data:image/s3,"s3://crabby-images/a16da/a16da21ee8b301ea2bde31b6248845ceaa23d74d" alt=""
我们来看一下一般前端构建的流程
data:image/s3,"s3://crabby-images/a8e7a/a8e7ab3cd1fe29a4b2424b5de95f324d168da74e" alt=""
一般情况下,我们是在脑子中是一流的方式来做事的。
二者处理流程的区别
Grunt 的方式
data:image/s3,"s3://crabby-images/260b8/260b83753d0118ac2fa6b0170bf2bbe018c3ac03" alt=""
Gulp的方式
data:image/s3,"s3://crabby-images/aa236/aa23673937848b56f9a6ab9cbe090da19536fb6c" alt=""
配置的简洁程度
Grunt
module.exports = function(grunt) {
// Project configuration.
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
uglify: {
options: {
banner: '/*! <%= pkg.name %> <%= grunt.template.today("yyyy-mm-dd") %> */\n'
} ,
build: {
src: 'src/<%= pkg.name %>.js',
dest: 'build/<%= pkg.name %>.min.js'
}
}
});
grunt.loadNpmTasks('grunt-contrib-uglify');
grunt.registerTask('default', ['uglify']);
};
Gulp
gulp.task('default',function(){
return gulp
.src("**/*.js")
.pipe(jshint())
.pipe(concat())
.pipe(uglify())
.pipe(gulp.dest('./build/'))
})
所以从上面的一些代码对比来看,Gulp明显比Grunt要简洁易用很多。
最后,总结一些 Grunt的一些问题
- 配置过于复杂
- 插件职责不单一 (就是不SRP)
- 临时文件目录多
- 性能慢 (因为临时文件多,自然读IO多)
下一篇我们将开始学习如何使用gulp来构建我们的前端。
网友评论