gulp 3.0 & 4.0 | watch task has to be a function问题

gulpfile.js

var gulp =require("gulp");
var sass = require("gulp-sass");

gulp.task('sass',()=>{
    return gulp.src('app/scss/**/*.scss')
    .pipe(sass())
    .pipe(gulp.dest('app/css'))
});


gulp.task('watch',()=>{
    gulp.watch('app/scss/**/*.scss', ['sass']);
});

复制代码

报错:

分析:

这个是由于require引入的包的版本问题导致的。在不同的版本里,接口参数发生了变化。在gulp4.0之后已经只能接受watch第二个参数必须为函数。详情请看官网

方法一:

查看版本:

下载或修改本地的Gulp版本为3.9.1:

成功解决:

方法二、

修改gulpfile.js

var gulp =require("gulp");
var sass = require("gulp-sass");

gulp.task('sass',()=>{
    return gulp.src('app/scss/**/*.scss')
    .pipe(sass())
    .pipe(gulp.dest('app/css'))
});


gulp.task('watch',()=>{
    gulp.watch('app/scss/**/*.scss', gulp.series('sass'));
});

复制代码

想了解gulp.series请访问:www.npmjs.com/package/und…

问题解决:

扩展:Browser Sync自动刷新

使用4.0可能会报错:

还好现在已经修改成3.9.1了

安装 browser-sync :

npm install browser-sync --save-dev
复制代码

gulpfile.js

var gulp = require("gulp");
var sass = require("gulp-sass");
var browserSync = require('browser-sync');

gulp.task('sass', () => {
    return gulp.src('app/scss/**/*.scss')
        .pipe(sass())
        .pipe(gulp.dest('app/css'))
        .pipe(browserSync.reload({
            stream: true
        }))
});

//先把browserSync和Sass任务执行了再说
gulp.task('watch',['browserSync','sass'], () => {
    gulp.watch('app/scss/**/*.scss', ['sass']);
});

//创建一个broswerSync任务
gulp.task('browserSync', () => {
    browserSync({
        server: {
            baseDir: 'app'
        },
    })
});
复制代码

成功,浏览器的显示的页面为app/index.html。你修改了styles.scss之后,浏览器将自动属性页面

可从《How do I resolve "Cannot find module" error using Node.js? - Stack Overflow》继续了解!!!

转载于:https://juejin.im/post/5c5f2eb7e51d457ffa36e18b

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值