gulp 入门使用
gulp 入门使用
使用场景
相信大家在传统的开发模式下 都是 html + css + js 然后静态文件不经过任何处理 部署到服务器,这样会有很多漏洞例如:
1.在网站上查看F12 就可以看到源代码(可以篡改提交参数)
2.代码高级语法不经过babel转换,导致低版本浏览器无法正常解析
3.代码不压缩导致文件过大
等等等等。。。。
复制代码
webpack 和 gulp 区别
gulp:强调的是前端开发的流程,通过配置一系列的task,定义task处理的事物(例如文件压缩合并、雪碧图、启动server、 版本控制等),然后定义执行顺序,来让gulp执行task,从而构建前端项目的流程
webpack:是一个前端模块化方案,侧重模块打包,把开发中的所有资源(图片、js文件、css文件等)都看成模块,通过loader(加载器)和plugins(插件)对资源进行处理,打包成符合生产环境部署的前端资源。相同:可以文件合并与压缩(css)不同点:虽然都是前端自动化构建工具,但看他们的定位就知道不是对等的。gulp严格上讲,模块化不是他强调的东西,他旨在规范前端开发流程。webpack更是明显强调模块化开发,而那些文件压缩合并、预处理等功能,不过是他附带的功能。
安装
- 全局安装 gulp:
$ npm install --global gulp
复制代码
- 作为项目的开发依赖(devDependencies)安装:
$ npm install --save-dev gulp
复制代码
- 在项目根目录下创建一个名为 gulpfile.js 的文件:
gulp.task('default', function() {
// 将你的默认的任务代码放在这
});
复制代码
- 运行 gulp: $ gulp
文件Demo目录结构
├── css
│ ├── index.css
│ ├── lottery.css
│ ├── perfectInformation.css
│ ├── personal.css
│ ├── reset.css
│ └── vote.css
├── favicon.ico
├── gulpfile.js
├── imgs
│ ├── 0.jpeg
│ ├── bg1.png
│ ├── bg2.png
│ ├── default.png
│ ├── down.png
│ ├── editInfo.png
│ ├── head_bg.png
│ ├── homeIndex.png
│ ├── index_bg.jpg
│ ├── lottery
│ │ ├── aoji.gif
│ │ ├── bg-lottery.png
│ │ ├── ly-plate-c.gif
│ │ ├── playbtn-aoji.png
│ │ └── playbtn.png
│ ├── perfectInformation_bg.png
│ ├── qrcode.png
│ ├── search.png
│ ├── voteIndex.png
│ └── wx-share.png
├── index.html
├── lib
│ ├── jquery-3.3.1.js
│ ├── jquery.rotate.min.js
│ ├── layer_mobile
│ │ ├── layer.js
│ │ └── need
│ │ └── layer.css
│ ├── qrcode.min.js
│ ├── rem.js
│ └── share.js
├── lottery.html
├── package-lock.json
├── package.json
├── perfectInformation.html
├── personal-share.html
├── personal.html
├── script
│ ├── index.js
│ ├── lottery.js
│ ├── perfectInformation.js
│ ├── personal-share.js
│ ├── personal.js
│ └── vote.js
└── vote.html
复制代码
.gulpfile.js编写
var gulp = require('gulp'),
htmlmin = require('gulp-htmlmin'),//压缩html插件
babel = require("gulp-babel"), // 用于ES6转化ES5
del = require('del'),//删除文件插件
cssmin = require("gulp-cssmin"),//css 压缩插件
less = require("gulp-less"),//less 转css插件
sass = require("gulp-sass"),//sass 转css插件
rename = require("gulp-rename"),//重命名插件
uglify = require("gulp-uglify");//js 压缩插件
//删除dist文件夹
gulp.task('clean', function () {
return del([
'dist'
])
})
//css压缩
gulp.task('css', function () {
return gulp.src("./css/*.css")
.pipe(cssmin())
.pipe(gulp.dest("./dist/css"));
});
//less转换 压缩
gulp.task('less', function () {
return gulp.src('./css/*.less')
.pipe(rename({
suffix: '.min'
}))
.pipe(less())
.pipe(gulp.dest("./dist/css"));
});
//图片拷贝到指定目录
gulp.task('imgs', function () {
gulp.src("./lib/**/*")
.pipe(gulp.dest("./dist/lib/"));
return gulp.src("./imgs/**/*")
.pipe(gulp.dest("./dist/imgs/"));
});
//javascript压缩
gulp.task('script', function () {
//将第三方压缩文件拷贝
gulp.src("./script/*.min.js")
.pipe(gulp.dest("./dist/script"));
gulp.src("./script/*.json")
.pipe(gulp.dest("./dist/script"));
//压缩非第三方min文件
return gulp.src("./script/!(*.min)*.js")
.pipe(babel({
presets: ['@babel/env']
}))
.pipe(uglify())
.pipe(gulp.dest("./dist/script"));
});
//html压缩
gulp.task('page', function () {
// 将你的默认的任务代码放在这
var options = {
removeComments: true, //清除HTML注释
collapseWhitespace: true, //压缩HTML
collapseBooleanAttributes: true, //省略布尔属性的值 <input checked="true"/> ==> <input checked />
removeEmptyAttributes: true, //删除所有空格作属性值 <input id="" /> ==> <input />
removeScriptTypeAttributes: true, //删除<script>的type="text/javascript"
removeStyleLinkTypeAttributes: true, //删除<style>和<link>的type="text/css"
minifyJS: true, //压缩页面JS
minifyCSS: true //压缩页面CSS
};
return gulp.src('*.html')
.pipe(htmlmin(options))
.pipe(gulp.dest('dist/'))
})
gulp.task('default', gulp.series('clean', 'css', 'script', 'imgs', 'page'), function () {
});
复制代码
执行gulp命令进行打包压缩
gulp
复制代码
打包后的代码都是经过压缩的
gulp 入门使用的更多相关文章
- Gulp入门教程(转载)
本人转载自: Gulp入门教程
- (转)前端构建工具gulp入门教程
前端构建工具gulp入门教程 老婆婆 1.8k 2013年12月30日 发布 推荐 10 推荐 收藏 83 收藏,20k 浏览 本文假设你之前没有用过任何任务脚本(task runner)和命令行工具 ...
- 《Gulp 入门指南》 : 使用 gulp 压缩 JS
<Gulp 入门指南> : 使用 gulp 压缩 JS 请务必理解如下章节后阅读此章节: 安装 Node 和 gulp 访问论坛获取帮助 压缩 js 代码可降低 js 文件大小,提高页面打 ...
- Gulp入门与解惑
Gulp简介 Gulp.js 是一个自动化构建工具,开发者可以使用它在项目开发过程中自动执行常见任务.Gulp.js是基于 Node.js构建的,利用Node.js流的威力,你可以快速构建项目. 安装 ...
- 【转】Gulp入门基础教程
Gulp入门基础教程 原文在此 前言最近流行前端构建工具,苦于之前使用Grunt,代码很难阅读,现在出了Gulp, 真是摆脱了痛苦.发现了一篇很好的Gulp英文教程,整理翻译给大家看看. 为什么使用G ...
- gulp入门与一些基本设置
这里是gulp入门的一些操作,实现了编译sass文件.压缩.合并.添加版本号等基本功能. 友情提示,如果npm出现无法下载可以安装 cnpm.在安装完Nodejs 后 npm install cnpm ...
- gulp入门演练
一直想学习下gulp看了蛮多资料,然后总是感觉是是而非,突然开窍了,把自己学会的过程给大家分享下,入门超级简单的 gulp安装 安装gulp 如果参数-g 表示全局安装 $ npm install g ...
- 前端小白的gulp入门
gulp新手入门 全局安装 cnpm install -g gulp 本地安装cnpm install gulp -D 如果项目没有package.json,记得npm init 安装插件cnpm i ...
- gulp入门学习教程(入门学习记录)
前言 最近在通过教学视频学习angularjs,其中有gulp的教学部分,对其的介绍为可以对文件进行合并,压缩,格式化,监听,测试,检查等操作时,看到前三种功能我的心理思想是,网上有很多在线压缩,在线 ...
随机推荐
- 面试被问烂的 Spring IOC(求求你别再问了)
广义的 IOC IoC(Inversion of Control) 控制反转,即"不用打电话过来,我们会打给你". 两种实现: 依赖查找(DL)和依赖注入(DI). IOC 和 D ...
- 利用 Blob 处理 node 层返回的二进制文件流字符串并下载文件
博客地址:https://ainyi.com/65 解释 | 背景 看到标题有点懵逼,哈哈,实际上是后端将文件处理成二进制流,返回到前端,前端处理这个二进制字符串,输出文件或下载 最近公司有个需求是用 ...
- 【开源分享】2018CRM C# 源码(基于小黄豆CRMv2.0.925.3版本功能更新)
分享出来的初衷,我分享一下最近我在小黄豆CRM2.0版本(小黄豆CRM+v2.0.925.3)上加的功能,如果有类似需求的,可以把功能代码发你,节约你的开发时间.(这是在小黄豆开源免费CRM①群231 ...
- git创建分支并提交到远程分支
来自:https://www.cnblogs.com/bluestorm/p/6252900.html 侵删 git branch(分支命令的使用http://hbiao68.iteye.com/bl ...
- 可以让你神操作的手机APP推荐 个个都是爆款系列
手机在我们的生活中显得日益重要,根据手机依赖度调查显示,69%的人出门时必带手机,20%的人经常在吃饭睡觉.上卫生间时使用手机:43%的人早上起床第一件事就是查看手机,不用多说,我们对于手机的依赖性越 ...
- 随笔:关于去年的WordPress建站的回忆
2018-02-26 建站 2018-02-28 选择主题Clearision 2018-03-01 学习插入视频.修改主题 <iframe src="//playe ...
- Java:API文档;文档注释中的javadoc标记;官方API;自己动手给项目建一个API文档
1.什么是API文档 在Java语言中有3种注释 //单行注释 /* 多行注释 */ /** * 文档注释 */ API(应用程序接口)文档就是用javadoc命令提取文档注释生成的,html格式,用 ...
- 快速排序实现及其pivot的选取
coursera上斯坦福的算法专项在讲到快速排序时,称其为最优雅的算法之一.快速排序确实是一种比较有效的排序算法,很多类库中也都采用了这种排序算法,其最坏时间复杂度为$O(n^2)$,平均时间复杂度为 ...
- java笔记----获取电脑上ip(内网ip)
private static String getHostIP(){ String tempIP = "127.0.0.1"; try { if(isIpv4(InetAddres ...
- Cannot connect to WMI Provider & Invalid class [0x80041010]
数据库服务器(Virtual Machine)所在的Nutanix一台主机由于故障,VM自动切换到另一台主机,切换过程中VM会重新启动,但是早上检查的时候,发现点击SQL Server Configu ...