相关代码已上传至github

怎么是项目构建?

  1. 编译项目中的js, sass, less;
  2. 合并js/css等资源文件;
  3. 压缩js/css/html等资源文件;
  4. JS语法的检查。

构建工具的作用?

简化项目构建, 自动化完成构建。

构建工具

grunt、gulp、webpack

grunt

1.官网:https://www.gruntjs.net/

2.参考文档:http://www.cnblogs.com/wangfupeng1988/p/4561993.html

3.常用的插件:
  1. * grunt-contrib-clean——清除文件(打包处理生成的)
  2. * grunt-contrib-concat——合并多个文件的代码到一个文件中
  3. * grunt-contrib-uglify——压缩js文件
  4. * grunt-contrib-jshint——javascript语法错误检查;
  5. * grunt-contrib-cssmin——压缩/合并css文件
  6. * grunt-contrib-htmlmin——压缩html文件
  7. * grunt-contrib-imagemin——压缩图片文件(无损)
  8. * grunt-contrib-copy——复制文件、文件夹
  9. * grunt-contrib-requirejs**——合并压缩requirejs管理的所有js模块文件
  10. * grunt-contrib-watch——实时监控文件变化、调用相应的任务重新执行

gulp

1.官网:https://www.gulpjs.com.cn/

2.相关插件:

  • * gulp-concat : 合并文件(js/css)
  • * gulp-uglify : 压缩js文件
  • * gulp-rename : 文件重命名
  • * gulp-less : 编译less
  • * gulp-clean-css : 压缩css
  • * gulp-livereload : 实时自动编译刷新
  • * 重要API
  • * gulp.src(filePath/pathArr) :
  • * 指向指定路径的所有文件, 返回文件流对象
  • * 用于读取文件
  • * gulp.dest(dirPath/pathArr)
  • * 指向指定的所有文件夹
  • * 用于向文件夹中输出文件
  • * gulp.task(name, [deps], fn)
  • * 定义一个任务
  • * gulp.watch()
  • * 监视文件的变化

webpack

1.https://www.webpackjs.com/

2.http://guowenfh.github.io/2016/03/24/vue-webpack-01-base

3.https://github.com/onface/webpack-book

4.https://www.jianshu.com/p/bb48898eded5

之前写过一篇关于webpack:https://www.cnblogs.com/zhengyeye/p/9260235.html

End

grunt与gulp指令大同小异,只是看自己喜好使用;

webpack其实更流行。

构建工具:grunt、Glup、webpack的更多相关文章

  1. 前端开发自动化工作流工具,JavaScript自动化构建工具grunt、gulp、webpack介绍

    前端开发自动化工作流工具,JavaScript自动化构建工具grunt.gulp.webpack介绍 前端自动化,这样的一个名词听起来非常的有吸引力,向往力.当今时代,前端工程师需要维护的代码变得及为 ...

  2. JavaScript自动化构建工具grunt、gulp、webpack介绍

    前端开发自动化工作流工具,JavaScript自动化构建工具grunt.gulp.webpack介绍 前端自动化,这样的一个名词听起来非常的有吸引力,向往力.当今时代,前端工程师需要维护的代码变得及为 ...

  3. 前端项目构建工具---Grunt

    什么是Grunt? grunt是javascript项目构建工具,在grunt流行之前,前端项目的构建打包大多数使用ant.(ant具体使用 可以google),但ant对于前端而言,存在不友好,执行 ...

  4. JavaScript 项目构建工具 Grunt 实践:安装和创建项目框架

     Grunt 是一个基于任务的 JavaScript 项目命令行构建工具,运行于 Node.js 平台.Grunt 能够从模板快速创建项目,合并.压缩和校验 CSS & JS 文件,运行单元测 ...

  5. 前端构建工具之争——Webpack vs Gulp 谁会被拍死在沙滩上

    .table tr>td:nth-child(1){width: 2em !important;padding-left: .6rem !important;padding-right: .6r ...

  6. JS模块化开发(二)——构建工具grunt

    gruntJs——构建工具:代码压缩.文件合并 安装流程: 1.到nodeJs官网下载安装nodeJs(附带了npm包管理工具) 2.cmd命令行:npm install -g grunt-cli / ...

  7. 前端构建工具 Grunt 入门

    之前也介绍过前端构建工具 Ant 和 Yeoman,其中 Yeoman 工具就包含了 Grunt 所以就不多说.那么与 Ant 相比 Grunt 有这么几个优点: Javascript 语法,相比 A ...

  8. 前端自动化构建工具Grunt

    一.了解Gurnt(http://www.open-open.com/lib/view/open1433898272036.html) Grunt 是一个基于任务的JavaScript工程命令行构建工 ...

  9. 自动构建工具Grunt

    摘要: 大部分项目在部署之前都需要做的就是js.css文件的压缩.合并,以及一些文件的错误检查,甚至是将LESS文件转换成css文件,coffeescript文件转化成js文件等等.但是项目开发是分迭 ...

  10. 前端打包构建工具grunt快速入门(大篇幅完整版)

    打包的目的和意义就不用叙述了直接上干货 http://www.gruntjs.net/getting-started里面的教程也太简单了,需要下一番功夫去研究才行.本文将grunt打包的常用方法都用实 ...

随机推荐

  1. [C++] const与重载

    下面的两个函数构成重载吗? void M(int a){} //(1) void M(const int a){} //(2) 下面的呢? void M(int& a){} //(3) voi ...

  2. SoapUI Pro Project Solution Collection-Custom project and setup

    import java.util.List; import java.util.Map; import org.apache.log4j.Logger; import com.eviware.soap ...

  3. ios实例开发精品源码文章推荐(8.22)

    1.iOS源码:简单阅读器 http://www.apkbus.com/android-112176-1-1.html 2.iOS源码:音频声效--Audio Streamer<ignore_j ...

  4. sql中索引不会被用到的几种情况

    1.查询谓词没有使用索引的主要边界,换句话说就是select *,可能会导致不走索引. 比如,你查询的是SELECT * FROM T WHERE Y=XXX;假如你的T表上有一个包含Y值的组合索引, ...

  5. 【C#】C#中的属性与字段

    目录结构: contents structure [+] 属性和字段的区别 无参属性 自动实现的属性 对象和集合初始化器 匿名类型 System.Tuple类型 有参属性 属性的可访问性 在这篇文章中 ...

  6. Nginx 日志自动分割

    Nginx 的日志都是写在一个文件当中的,不会自动地进行切割,如果访问量很大的话,将导致日志文件容量非常大,不便于管理和造成Nginx 日志写入效率低下等问题.所以,往往需要要对access_log. ...

  7. 第三部分:Android 应用程序接口指南---第二节:UI---第五章 设置(Settings)

    第5章 设置(Settings) 应用程序通常包括允许用户修改应用程序的特性和行为的设置功能.例如,一些应用程序允许用户指定通知是否启用或指定多久使用云同步数据.如果你想要为你的应用程序提供设置,你应 ...

  8. FFmpeg: AVPacket 结构体分析

    AVPacket是FFmpeg中很重要的一个数据结构,它保存了解封装之后,解码之前的数据(注意:仍然是压缩后的数据)和关于这些数据的一些附加信息,如显示时间戳(pts).解码时间戳(dts).数据时长 ...

  9. Maven使用详解,非常详细

    本文转:http://blog.csdn.net/u010425776/article/details/52027706 什么是Maven? 如今我们构建一个项目需要用到很多第三方的类库,如写一个使用 ...

  10. Linux嵌入式时区修改