gulp--快速入门

前言

这里需要特别注意,gulp需要先全局安装,然后根据项目,在本地安装

名称作用
npm install -g gulp全局安装gulp
npm install gulp --save-dev本地安装gulp

步骤

在安装完gulp后,在项目中新建gulpfile.js

在这里插入图片描述
在这里插入图片描述
内容如图所示:
然后我们运行下:
在这里插入图片描述
发现报错啊,这就是我没有全局安装的结果啊,我全局安装完后,在运行就可以了

在这里插入图片描述
说明gulp可以正式运行了.

一整套压缩js/css/image等流程示范

假设你刚重装完系统
接下来,你需要

1.下载nodejs,然后安装
2.打开cmd,输入 gulp -v ,查看gulp版本;然后告诉你,gulp不是内部命令,也就是还没有安装
3.全局安装gulp
$ npm install gulp -g // 注意,前面的$符号是Linux系统下的,不用写,Windows的是#号
在这里,我竟然报错了:npm ERR! Unexpected end of JSON input while parsing near ‘…},“0.10.31”:{“name”:"’
好吧,百度了一下,贴上解决的办法:

  1. 首先输入 npm cache clean --force
  2. 然后输入 npm install gulp -g
    漫长的等待安装吧…

然后我搞定了,截图如下:
在这里插入图片描述

然后在本地建立文件夹进行测试:

在这里插入图片描述
这是我的目录,测试js的
在建完目录前,需要进行本地安装gulp和其插件
在这里插入图片描述
在这里插入图片描述
这里我是没报什么错,然后配置下gulpfile.js
在这里插入图片描述
然后编写一些测试js
在这里插入图片描述
然后进行压缩啊,可以看到压缩后的代码啊,进行了混淆了
在这里插入图片描述
然后安装能压缩css的插件

npm install gulp-clean-css

在这里插入图片描述
打包之后引入到main.html中,试一下,发现确实没有问题

但是我们比较习惯于在生产环境使用jquery.min.js类似的压缩文件,这就需要我们引入重命名模块

npm install gulp-rename --save-dev

// 获取 gulp
var gulp = require('gulp');
// 获取 uglify 模块(用于压缩 JS)
var uglify = require('gulp-uglify');
// 获取 cleancss 模块(用于压缩 CSS)
var cleanCSS = require('gulp-clean-css');
// 获取重命名模块
var rename = require("gulp-rename");


// 压缩 js 文件
// 在命令行使用 gulp js 启动此任务
gulp.task('js', function () {
    // 1. 找到文件
    return gulp.src('js/*.js')
        .pipe(rename({
            suffix: '.min'
        }))
        // 2. 压缩文件
        .pipe(uglify())
        // 3. 另存压缩后的文件
        .pipe(gulp.dest('dist/js'));
});
// 压缩 css 文件
// 在命令行使用 gulp css 启动此任务
gulp.task('css', function () {
    // 1. 找到文件
    return gulp.src('css/*.css')
        .pipe(rename({
            suffix: '.min'
        }))
        // 2. 压缩文件
        .pipe(cleanCSS())
        // 3. 另存压缩后的文件
        .pipe(gulp.dest('dist/css'));
});

但是,我们每次写完了,总要手动的去编译压缩,那确实很麻烦,所以,我们希望能自动的编译压缩,像下面这样写

// 在命令行使用 gulp auto 启动此任务
gulp.task('autom', function () {
    // 监听文件修改,当文件被修改则执行 script 任务
    gulp.watch('js/*.js',['js']);
    gulp.watch('css/*.css', ['css']);
});

但是运行后,我发现各种报错啊
在这里插入图片描述
然后百度了下,发现是版本的问题,改成下面这样就行了

// 在命令行使用 gulp auto 启动此任务
gulp.task('autom', function () {
    // 监听文件修改,当文件被修改则执行 script 任务
    gulp.watch('js/*.js', gulp.series("js"));
    gulp.watch('css/*.css', gulp.series("css"));
});

然后我们每次用gulp autom就能自动监视了;
但是我只想输入gulp进行监视怎么办?

// 使用 gulp.task('default') 定义默认任务
// 在命令行使用 gulp 启动 script 任务和 auto 任务
gulp.task('default', gulp.series("autom"));

亲测有效

附上完整的gulpfile.js配置

// 获取 gulp
var gulp = require('gulp');
// 获取 uglify 模块(用于压缩 JS)
var uglify = require('gulp-uglify');
// 获取 cleancss 模块(用于压缩 CSS)
var cleanCSS = require('gulp-clean-css');
// 获取重命名模块
var rename = require("gulp-rename");


// 压缩 js 文件
// 在命令行使用 gulp js 启动此任务
gulp.task('js', function () {
    // 1. 找到文件
    return gulp.src('js/*.js')
        .pipe(rename({
            suffix: '.min'
        }))
        // 2. 压缩文件
        .pipe(uglify())
        // 3. 另存压缩后的文件
        .pipe(gulp.dest('dist/js'));
});
// 压缩 css 文件
// 在命令行使用 gulp css 启动此任务
gulp.task('css', function () {
    // 1. 找到文件
    return gulp.src('css/*.css')
        .pipe(rename({
            suffix: '.min'
        }))
        // 2. 压缩文件
        .pipe(cleanCSS())
        // 3. 另存压缩后的文件
        .pipe(gulp.dest('dist/css'));
});

// 在命令行使用 gulp auto 启动此任务
gulp.task('autom', function () {
    // 监听文件修改,当文件被修改则执行 script 任务
    gulp.watch('js/*.js', gulp.series("js"));
    gulp.watch('css/*.css', gulp.series("css"));
});

// 使用 gulp.task('default') 定义默认任务
// 在命令行使用 gulp 启动 script 任务和 auto 任务
gulp.task('default', gulp.series("autom"));
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李卓书

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值