网站首页 > 技术文章 正文
@Author : Runsen
@Date : 2019/12/19
gulp
gulp是基于流的前端构件化工具。gulp是自动化项目的构建利器;不仅能对网站资源进行优化,而且在开发过程中很多重复的任务能够使用正确的工具自动完成。同时使用非常简单,学习成本低。这个压缩工具也是前端必学的的工具。
环境搭建
- node 因为npm跟随node的包安装管理工具。具体下载直接百度nodejs中文网,根据自身的环境(windows linux mac)下载安装包(msi)。直接进行安装。
- npm install -g gulp 安装成功后就可以在命令行输入gulp相关的命令了
安装成功后,输入gulp -v 查看版本
在项目中安装 npm install --save-dev gulp,安装成功后就可以开始写配置文件了。
环境开发
- vscode
- nodejs
- gulp
gulp入门
npm init 项目初始化 ,此时根目录会出现package.json
npm install gulp --save-dev 在本地项目局部安装gulp
创建gulpfile.js文件
// 以下代码会执行在node环境下
var gulp = require( "gulp" );
// 创建一个gulp的任务
gulp.task( "default",function(done){
console.log( "hello gulp" );
done();
} );
在命令行执行gulp default
压缩css
npm install gulp-cssnano --save -dev 在本地项目安装gulp-cssnano
新建一个css文件夹,在新建index.css
*{
margin: 0;
padding: 0;
}
p{
color: red
}
gulpfile.js代码如下
var gulp = require('gulp');
// 需要先安装gulp-cssnano
var cssnano = require('gulp-cssnano');
// 定义一个处理css文件改动的任务
gulp.task('css',function(){
gulp.src('./css/*.css')
.pipe(cssnano())
.pipe(gulp.dest("./dist/css/"))
});
新建dist文件夹来存放生成的css任务
执行 gulp css
在dist文件夹的css文件夹生成了index.css *{margin:0;padding:0}p{color:red} gulp 修改压缩的文件名
npm install gulp-rename --save-dev 在本地项目安装
gulpfile.js代码修改如下
var gulp = require('gulp');
// 需要先安装gulp-cssnano
var cssnano = require('gulp-cssnano');
var rename = require('gulp-rename')
// 定义一个处理css文件改动的任务
gulp.task('css',function(){
// 处理css文件的目录
return gulp.src('./css/*.css')
.pipe(cssnano())
// 将index.css生成index.min.css
.pipe(rename({"suffix":".min"}))
.pipe(gulp.dest("./dist/css/"))
});
执行 gulp css,这样将index.css命名为index.min.css
js压缩
npm install gulp-uglify --save-dev 安装js压缩插件
同样的道理新建js文件夹新建index.js
代码是生成斐波那契数组
function getFibonacci(n) {
var fibarr = [];
var i = 0;
while(i<n) {
if(i<=1) {
fibarr.push(i);
}else{
fibarr.push(fibarr[i-1] + fibarr[i-2])
}
i++;
}
return fibarr;
}
gulpfile.js代码修改如下
var gulp = require('gulp');
var rename = require('gulp-rename');
var uglify = require('gulp-uglify')
// 对js请求进行压缩和混淆
// 定义任务
gulp.task('myscript', function() {
// 1.匹配要处理的文件
return gulp.src('src/js/*.js')
// 2.将js代码压缩混淆
.pipe(uglify())
.pipe(rename({"suffix":".min"}))
.pipe(gulp.dest('./dist/js'))
})
执行 gulp myscript
index.min.js代码就会压缩
function getFibonacci(n){for(var r=[],u=0;u<n;)u<=1?r.push(u):r.push(r[u-1]+r[u-2]),u++;return r}
html 压缩
npm install gulp-htmlmin --save-dev
新建html文件夹在新建index.html
gulpfile.js代码修改如下
var gulp = require('gulp');
var rename = require('gulp-rename');
// 对html进行压缩的包
var htmlmin = require('gulp-htmlmin')
// 对html进行压缩
// 定义任务
gulp.task('myhtml', function(){
// 1.匹配到要处理的html文件
return gulp.src('./html/*.html')
// 2.对html进行压缩!
.pipe(htmlmin({
collapseWhitespace:true // 去除空白符
}))
// 3.输出
.pipe(rename({"suffix":".min"}))
.pipe(gulp.dest('dist/html'))
})
执行 gulp myhtml
index.html就会被压缩
使用gulp 压缩代码能使项目运行更加的流畅。
猜你喜欢
- 2024-12-02 Squoosh - 谷歌出品的免费开源图片压缩工具,压缩90%,支持 API 调用
- 2024-12-02 实用技巧分享:你知道如何实现油猴脚本的导出与本地导入吗?
- 2024-12-02 详细介绍一下Spring Boot中对于文件的压缩以及解压缩操作?
- 2024-12-02 前端入门——html 中如何使用图片
- 2024-12-02 超好用 Vue.js 图片裁切组件Vue-ImgCutter
- 2024-12-02 Vue项目优化篇
- 2024-12-02 热门在线图片压缩工具,一次解决平时在办公时遇到的压缩问题
- 2024-12-02 Java pdf下载优化:Java图片压缩
- 2024-12-02 在线图片压缩效果怎么样?有没有免费的工具?
- 2024-12-02 手搓一个TinyPng压缩图片的WebpackPlugin
你 发表评论:
欢迎- 07-08记oracle日志挖掘实操&查询归档不正常增长情况(一)
- 07-08Oracle 伪列!这些隐藏用法你都知道吗?
- 07-08orcl数据库查询重复数据及删除重复数据方法
- 07-08重大故障!业务核心表被truncate删除,准备跑路……
- 07-08oracle数据恢复—oracle执行truncate命令误删除数据的数据恢复
- 07-08Oracle-rac 修改scanip(oracle 修改sequence cache)
- 07-08ORACLE RAC CDB和PDB切换(oracle数据库rac切换)
- 07-08Oracle rac haip作用(oracle rac的典型特征)
- 596℃几个Oracle空值处理函数 oracle处理null值的函数
- 590℃Oracle分析函数之Lag和Lead()使用
- 577℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 573℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 569℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 562℃【数据统计分析】详解Oracle分组函数之CUBE
- 549℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 542℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- 记oracle日志挖掘实操&查询归档不正常增长情况(一)
- Oracle 伪列!这些隐藏用法你都知道吗?
- orcl数据库查询重复数据及删除重复数据方法
- 重大故障!业务核心表被truncate删除,准备跑路……
- oracle数据恢复—oracle执行truncate命令误删除数据的数据恢复
- Oracle-rac 修改scanip(oracle 修改sequence cache)
- ORACLE RAC CDB和PDB切换(oracle数据库rac切换)
- Oracle rac haip作用(oracle rac的典型特征)
- 新手小白怎么学UI设计 推荐学习路线是什么
- 超实用!0基础UI设计自学指南(0基础学ui设计好就业吗)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端懒加载 (49)
- 前端获取当前时间 (50)
- 前端接口 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)