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 (简单配置)
项目上线也有一阵子,回头过来看了看从最初的项目配置到开发的过程,总有些感慨,疲软期,正好花点时间,看看最初的配置情况 随着前端的发展,前端工程化慢慢成为业内的主流方式,项目开发的各种构建工具,也出现了 ...
随机推荐
- windows管理命令
执行msi程序 msiexec /package mysql-installer-community-5.7.18.0.msi rem 管理员DOS窗口执行这个命令,开始卸载mysql 杀死进程 ta ...
- Yii2 关于yii\db\Connection::open耗时很久的问题(1000ms左右)
关于这个问题我纠结了很久,每次打开网页yii\db\Connection::open几乎都耗时1000ms. 其实这个问题很好解决:只要把config\db.php配置信息里的localhost,改成 ...
- Requests抓取有道翻译结果
Requests比urllib更加方便,抓取有道翻译非常的简单. import requests class YouDao(): def __init__(self,parm): ...
- struts2--Action
HTTP请求 提交 Struts2 StrutsPrepareAndExecuteFilter 核心控制器 -- 请求分发给不同Action Action书写的的三种格式 第一种 Action可以是 ...
- 线性代数-矩阵-【5】矩阵化简 C和C++实现
点击这里可以跳转至 [1]矩阵汇总:http://www.cnblogs.com/HongYi-Liang/p/7287369.html [2]矩阵生成:http://www.cnblogs.com/ ...
- 后PMP时代下的敏捷项目管理全国在线讲座
活动时间:2017年9月7日(周四) 19:00-21:00 活动形式:在线直播 本次活动免费 互联网经济冲击下,产品创新成为企业生存的关键,"双模"成为很多企业必然的选择,传统 ...
- MariaDB体验1----数据库安装
之前一直都是使用的微软Sql Server数据库,现在在学习数据分析,要用到mysql.刚好公司在进行云架构升级,数据库选型为MariaDB,就顺势安装体验了一把MariaDB.这里记录一下学习过程. ...
- git 工作流介绍
GIT Git工作流你可以理解为工作中团队成员遵守的一种代码管理方案,在Git中有以下几种工作流方案作为方案指导: 集中式工作流 功能开发工作流 Gitflow工作流 Forking工作流 下面针对性 ...
- adb命令安装apk 来学习吧
1.将需要安装的apk放在platform-tools下 2.将手机和电脑连接,在cmd中输入 adb devices查看 3.使用adb命令安装apk,在cmd中输入:adb install apk ...
- 深入剖析ConcurrentHashMap 一
详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt201 ConcurrentHashMap是Java5中新增加的一个线程安全的 ...