forked from dream-num/Luckysheet
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathgulpfile.js
More file actions
87 lines (78 loc) · 2.08 KB
/
gulpfile.js
File metadata and controls
87 lines (78 loc) · 2.08 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
const gulp = require('gulp');
// gulp 核心方法
const { src, dest, series, parallel, watch } = require('gulp');
// gulp压缩js
const uglify = require('gulp-uglify');
// gulp判断
const gulpif = require('gulp-if');
// gulp压缩css
const cleanCSS = require('gulp-clean-css');
// 删除文件
const del = require('delete');
// 实时刷新浏览器
const browserSync = require('browser-sync').create();
const reload = browserSync.reload;
// 文件合并
const useref = require('gulp-useref');
// uglify js压缩配置 https://github.com/mishoo/UglifyJS#minify-options
const uglifyOptions = {
compress: {
drop_console: true
}
}
// 清除dist目录
function clean() {
return del(['dist']);
}
//监听文件+重载
function watchReload() {
serve();
const watcher = watch(['src/**']);
// 多次刷新节流
let reloadTimer = null;
watcher.on('change', function (path, stats) {
if (reloadTimer !== null) {
return;
}
reloadTimer = setTimeout(() => {
reload();
reloadTimer = null;
}, 500);
});
}
// 打包js
function js() {
return src(['src/**/*.html', '!src/lib/**'])
.pipe(useref(), function () {
return vinylPaths(del)
})
.pipe(gulpif(isJavaScript, uglify(uglifyOptions)))
.pipe(gulpif(isCss, cleanCSS()))
.pipe(dest('dist/'))
}
// 打包其他文件
function otherFile() {
return src(['src/**', '!src/**/*.html', '!src/**/*.js', '!src/**/*.css', '!src/lib/**'])
.pipe(dest('dist/'))
}
// 静态服务器
function serve() {
browserSync.init({
server: {
baseDir: "src"
}
});
}
// 判断文件的扩展名是否是 '.js' , 且需要为未压缩过的js
function isJavaScript(file) {
return file.extname === '.js';
}
// 判断文件的扩展名是否是 '.css' , 且需要为未压缩过的css
function isCss(file) {
return file.extname === '.css';
}
const build = series(clean, parallel(js, otherFile));
const dev = watchReload;
exports.build = build;
exports.dev = dev;
exports.default = build;