-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy pathgulpfile.js
196 lines (184 loc) · 6.57 KB
/
gulpfile.js
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
const gulp = require("gulp");
const browserSync = require("browser-sync").create();
const sass = require("gulp-sass");
const sourcemaps = require("gulp-sourcemaps");
const autoprefixer = require("gulp-autoprefixer");
const cleanCSS = require('gulp-clean-css');
const notify = require("gulp-notify");
const rename = require("gulp-rename");
const del = require("del");
const path = require("path");
const fs = require("fs");
const replaceCommon = require("gulp-replace-common");
const src = "./src/";
const dist = "./dist/";
const config = {
files: dist + "**/*.*",
html: {
src: dist + "**/*.html",
dest: dist
},
css: {
src: dist + "css/**/*.css",
dest: dist + "css"
},
scss: {
src: [src + "scss/**/*.scss", src + "sass/**/*.scss"],
dest: dist + "css"
}
};
var dir = __dirname.split("\\").reverse()[0].toLowerCase();
if (dir != 'h5' && dir != 'pc') {
dir = (path.normalize(__dirname + "\\..")).split("\\").reverse()[0].toLowerCase();
}
const browsers = dir == 'h5' ? ['last 10 versions'] : ['last 100 versions'];
function errorHandler() {
var args = Array.prototype.slice.call(arguments);
notify.onError({
title: "错误了",
message: "<%=error.message %>"
}).apply(this, args);
this.emit();
}
function argsHandler(ext) {
var file = '';
var globalFile = '';
var isReverse = false;
process.argv.forEach(function(arg) {
if (arg.indexOf("--") === 0) {
globalFile = arg.substring(2);
}
if (arg == "-reverse") {
isReverse = true;
}
});
if (globalFile) {
switch (ext) {
case 'scss':
file = globalFile.indexOf(".scss") > -1 ? globalFile : globalFile+".scss";
file = [src + "scss/**/" + file, src + "sass/**/" + file];
break;
case 'css':
file = globalFile.indexOf(".css") > -1 ? globalFile : globalFile +".css";
file = dist + "css/**/" + file;
break;
case 'html':
file = globalFile.indexOf(".html") > -1 ? globalFile : globalFile +".html";
file = dist + "**/" + file;
break;
}
} else {
switch (ext) {
case 'scss':
file = config.scss.src;
break;
case 'css':
file = config.css.src;
break;
case 'html':
file = config.html.src;
break;
}
}
return {file: file, isReverse: isReverse};
}
gulp.task("default", ["watch"], function() {
console.log("\
_ooOoo_\n\
o8888888o\n\
88\" . \"88\n\
(| -_- |)\n\
O\\ = /O\n\
____/`---'\\____\n\
.' \\\\| |// `.\n\
/ \\\\||| : |||// \\\n\
/ _||||| -:- |||||- \\\n\
| | \\\\\\ - /// | |\n\
| \\_| ''\\---/'' | |\n\
\\ .-\\__ `-` ___/-. /\n\
___`. .' /--.--\\ `. . __\n\
.\"\" '< `.___\\_<|>_/___.' >'\"\".\n\
| | : `- \\`.;`\\ _ /`;.`/ - ` : | |\n\
\\ \\ `-. \\_ __\\ /__ _/ .-` / /\n\
======`-.____`-.___\\_____/___.-`____.-'======\n\
`=---='\n\
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n\
佛祖保佑 永无BUG\n\
");
});
// 浏览器自动刷新 (gulp watch)
gulp.task("watch", function() {
var exists = fs.existsSync(dist + "index.html");
browserSync.init({
server: {
baseDir: dist,
directory: !exists
},
open: "external",
notify: false
});
gulp.watch(config.scss.src, ["sass"]);
gulp.watch(config.files).on("change", function() {
setTimeout(browserSync.reload, 100);
});
});
// sass编译成css (gulp sass)
gulp.task("sass", function() {
var filepath = argsHandler("scss").file;
return gulp.src(filepath)
.pipe(sourcemaps.init())
.pipe(sass())
.on("error", errorHandler)
.pipe(autoprefixer({
browsers: browsers
}))
.pipe(cleanCSS({ compatibility: 'ie8', keepBreaks: false }))
.pipe(rename({ suffix: '.min' }))
.pipe(sourcemaps.write("./maps"))
.pipe(gulp.dest(config.scss.dest));
});
// 替换global里的公共文件
gulp.task("replace", ['autoprefixer'], function() {
del("dist/css/maps");
var args = argsHandler("html");
var filepath = args.file;
var isReverse = args.isReverse;
var dirpath = filepath.indexOf("**/") > -1 ? config.html.dest : path.dirname(filepath);
return gulp.src(filepath)
.pipe(replaceCommon({reverse: isReverse}))
.pipe(gulp.dest(dirpath));
});
// css添加webkit,moz等前缀 (gulp autoprefixer)
gulp.task("autoprefixer", function() {
var filepath = argsHandler("css").file;
return gulp.src(filepath)
.pipe(autoprefixer({
browsers: browsers
}))
.pipe(cleanCSS({ compatibility: 'ie8', keepBreaks: false }))
.pipe(gulp.dest(config.css.dest));
});
// 压缩CSS (gulp cssmin)
gulp.task("cssmin", function() {
var filepath = argsHandler("css").file;
return gulp.src(filepath)
.pipe(cleanCSS({ compatibility: 'ie8', keepBreaks: false }))
.pipe(gulp.dest(config.css.dest));
});
gulp.task('help', function() {
console.log("------------------------------------------------------------");
console.log(" gulp 自动刷新并编译所有sass文件");
console.log(" gulp watch 自动刷新并编译所有sass文件");
console.log(" gulp watch --file 自动刷新并编译指定sass文件");
console.log(" gulp sass 编译sass文件");
console.log(" gulp sass --file 编译指定file文件");
console.log(" gulp autoprefixer 添加webkit等前缀");
console.log(" gulp autoprefixer --file 添加webkit等前缀");
console.log(" gulp cssmin 压缩CSS");
console.log(" gulp cssmin --file 压缩指定file文件");
console.log(" gulp replace 替换global下公共文件");
console.log(" gulp replace -reverse 逆替换global下公共文件");
console.log(" gulp replace --file 指定file文件替换global下公共文件");
console.log(" gulp replace -reverse --file 指定file文件逆替换global下公共文件");
console.log("------------------------------------------------------------");
});