JavaScript自动化构建工具入门----grunt、gulp、webpack
蛮荒时代的程序员:
自动化时代的程序员:
简单介绍三种工具
安装node.js及npm
grunt、gulp、webpack这三种自动化构建工具都依赖node.js环境,所以我们需要先安装node -- node官网 戳这里
//查看node版本
node -v
//查看npm版本
npm -v
//1.关闭npmssl严格认证
npmconfig set strict-ssl false
//2.安装cnpm -g全局包
npm install -g cnpm --registry-https://registry.npm.taobao.org/
grunt
//安装全局grunt命令CLI 在任何目录下都可以使用grunt命令只不过无法执行
//
npm install -g grunt-cli
//创建工程目录
mkdir 目录名
//切换到当前目录
cd 目录名
//初始化工程
npm init
//安装本地grunt安装包
//目的:多个版本可以在电脑上共存
npm install grunt --save-dev
//创建Gruntfile.js文件,用来配置或定义任务(task)并加载Grunt插件
//下面单独说 Gruntfile.js文件 的配置
//安装各种grunt插件 --参考方官
grunt-contrib-less less编译
grunt-contrib-cssmin css压缩
grunt-contrib-uglify js压缩
grunt-contrib-concat 合并
grunt-contrib-watch 监控
//执行任务task
grunt
关于Gruntfile.js文件配置:
Gruntfile.js文件配置需要和文件目录相结合,下面是个模板的文件tree :
│ Gruntfile.js
│ package.json
│
├─node_modules
│
└─src
├─concat
├─css
│ └─min
├─js
│ └─min
└─less
下面是Gruntfile.js文件配置:
module.exports = function(grunt) {
// Project configuration.
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
less:{
development:{
files:[{
expand:true,
cwd:'src/less',
src:['*.less'],
dest:'src/css',
ext:'.css'
}]
}
},
cssmin:{
options: {
banner: '/*! <%= pkg.name %> <%= grunt.template.today("yyyy-mm-dd") %> */\n'
},
static_mappings:{
files:[
{
expand:true,
cwd:'src/css',
src:'*.css',
dest:'src/css/min',
ext:'.min.css'
}
]
}
},
uglify: {
options: {
banner: '/*! <%= pkg.name %> <%= grunt.template.today("yyyy-mm-dd") %> */\n'
},
static_mappings:{
files:[
{
expand:true,
cwd:'src/js',
src:'*.js',
dest:'src/js/min',
ext:'.min.js'
}
]
}
},
concat:{
//压缩合并的 js 和css
distjs:{
src:['src/js/min/*.js'],
dest:'src/concat/all.js'
},
distcss:{
src:['src/css/min/*.css'],
dest:'src/concat/all.css'
}
},
watch:{
//监控文件变化并执行相应任务
files:['src/**/*.*'],
tasks:['less','cssmin','uglify','concat']
}
});
// 加载包含 "less" 任务的插件,less编译成css。
grunt.loadNpmTasks('grunt-contrib-less');
grunt.loadNpmTasks('grunt-contrib-cssmin');
grunt.loadNpmTasks('grunt-contrib-uglify');
grunt.loadNpmTasks('grunt-contrib-concat');
grunt.loadNpmTasks('grunt-contrib-watch');
grunt.registerTask('default', ['less','cssmin','uglify','concat','watch']);
};
gulp
//创建工程目录
mkdir 目录名
//切换到当前目录
cd 目录名
//初始化工程进行配置文件
npm init
//安装gulp
//注册全局 gulp
npm install –g gulp
//安装本地gulp
npm install gulp --save-dev
//创建grunt配置文件gulpfile.js 粘过去
//创建build 和 src原文件(css js less在 js 文件夹内创建min文件)
//安装插件 自带watch
npm install gulp-less --save-dev
npm install gulp-concat --save-dev (js css都合并)
npm install gulp-uglify --save-dev
npm install gulp-minify-css --save-dev
//执行
gulp
webpack
//全局安装webpack
npm install webpack -g
//在项目中安装 webpack
// 初始化 package.json, 根据提示填写 package.json 的相关信息
npm init
// 将 webpack 依赖添加到package.json
npm install webpack --save-dev
//Develop Server 工具 (可选)
npm install webpack-dev-server --save-dev
JavaScript自动化构建工具入门----grunt、gulp、webpack的更多相关文章
- 前端开发自动化工作流工具,JavaScript自动化构建工具grunt、gulp、webpack介绍
前端开发自动化工作流工具,JavaScript自动化构建工具grunt.gulp.webpack介绍 前端自动化,这样的一个名词听起来非常的有吸引力,向往力.当今时代,前端工程师需要维护的代码变得及为 ...
- JavaScript自动化构建工具grunt、gulp、webpack介绍
前端开发自动化工作流工具,JavaScript自动化构建工具grunt.gulp.webpack介绍 前端自动化,这样的一个名词听起来非常的有吸引力,向往力.当今时代,前端工程师需要维护的代码变得及为 ...
- gulp前端自动化构建工具入门篇
现在我们通过这3个问题来学习一下: 1.什么是gulp? 2.为什么要用gulp? 3.怎么用? 什么是gulp 答:是一个前端自动化的构建工具,直白点说,如果没有这个工具,我们利用人工依旧可以做 ...
- grunt,gulp,webpack前端打包工具的特性
1.http://www.cnblogs.com/lovesong/p/6413546.html (gulp与webpack的区别) 2.http://blog.csdn.net/qq_3231263 ...
- 亚信UED前端流程自动化构建工具
亚信UED前端流程自动化构建工具 .wmd-input, .wmd-input:focus, #md-section-helper {font-size: 14px !important;line-h ...
- 前端自动化构建工具--Gulp&&Webpack
前端构建工具的作用可以认为是对源项目文件或资源进行文件级处理,将文件或资源处理成需要的最佳输出结构和形式. 在处理过程中,我们可以对文件进行模块化引入.依赖分析.资源合并.压缩优化.文件嵌入.路径替换 ...
- 前端项目自动化构建工具——Webpack入门教程
参考资料:https://www.webpackjs.com/(中文文档) https://www.webpackjs.com/(官方文档) 首先有必要说明一下,本文侧重讲解webpack基本配置 ...
- gulp前端自动化构建工具新手入门篇
很久没有更新博文了. 经过了一次年前吐血的赶项目,终于在年后回血了.趁着有空,新学到了一个前端自动化构建工具-gulp. 现在我们通过这3个问题来学习一下: 1.什么是gulp? 2.为什么要用gul ...
- 基于流的自动化构建工具------gulp (简单配置)
项目上线也有一阵子,回头过来看了看从最初的项目配置到开发的过程,总有些感慨,疲软期,正好花点时间,看看最初的配置情况 随着前端的发展,前端工程化慢慢成为业内的主流方式,项目开发的各种构建工具,也出现了 ...
随机推荐
- 常用路径 URL 中的斜杠与反斜杠
常用路径中的斜杠与反斜杠... ------------------------------ 斜杠:反斜杠:======================电脑能识别的斜杠有两种:斜杠分正斜杠(forwa ...
- 使用canvas进行图像编辑
前面的话 本文将分为几个小功能的形式来详细介绍canvas图像编辑 缩放 下面是一张分析图,假设默认情况下,图片和canvas宽高相同.图片的缩放(scale)范围为0.5到3,缩放时改变的是图片的大 ...
- DeepLearning.ai学习笔记(一)神经网络和深度学习--Week3浅层神经网络
介绍 DeepLearning课程总共五大章节,该系列笔记将按照课程安排进行记录. 另外第一章的前两周的课程在之前的Andrew Ng机器学习课程笔记(博客园)&Andrew Ng机器学习课程 ...
- sort与qsort的用法,建议使用sort
做ACM题的时候,排序是一种经常要用到的操作.如果每次都自己写个冒泡之类的O(n^2)排序,不但程序容易超时,而且浪费宝贵的比赛时间,还很有可能写错.STL里面有个sort函数,可以直接对数组排序,复 ...
- 基于linux vim环境python代码自动补全
(一)简述 在使用vim编写python文件的过程中,默认的vim不会实现代码补全功能,在写程序或者是改程序的时候不是很方面,很容易出错,但是vim提供了各种插件,其中包括这个python文件的自动补 ...
- [2014-08-17]Mac OSX 截图快捷键
系统:OSX 10.9.4 内容来自网络,存于此以便查阅 基本操作 全屏截图:Command-Shift-3 指定区域截图:Command-Shift-4 指定窗口截图:Commnad-Shift-4 ...
- Python 的经典入门书籍有哪些?
是不是很多人跟你说,学Python开发就该老老实实地找书来看,再配合死命敲代码?电脑有了,软件也有了,心也收回来了?万事俱备,唯独只欠书籍?没找到到合适的书籍?可以看看这些. 1.Python基础教程 ...
- UWP 手绘视频创作工具技术分享系列
开篇先来说一下写这篇文章的初衷. 初到来画,通读了来画 UWP App 的代码,发现里面确实有很多比较高深的技术点,同时也是有很多问题的,扩展性,耦合,性能,功能等等.于是我们决定从头重构这个产品,做 ...
- Oracle实现分页查询的SQL语法汇总
1.无ORDER BY排序的写法.(效率最高) 经过测试,此方法成本最低,只嵌套一层,速度最快!即使查询的数据量再大,也几乎不受影响,速度依然! sql语句如下: ) TABLE_ALIAS ; 2. ...
- [js高手之路]Vue2.0基于vue-cli+webpack父子组件通信教程
在git命令行下,执行以下命令完成环境的搭建: 1,npm install --global vue-cli 安装vue命令行工具 2,vue init webpack vue-demo 使用v ...