-
Notifications
You must be signed in to change notification settings - Fork 90
/
Copy pathgulpfile.js
210 lines (192 loc) · 7.58 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
197
198
199
200
201
202
203
204
205
206
207
208
209
/*
gulp -v命令应该对应以下版本,否则部分功能不兼容
CLI version: 2.3.0
Local version: 4.0.2
*/
const fs = require('fs');
const os = require('os');
const gulp = require('gulp');
const del = require('del') // //清空目录下资源
const htmlmin = require('gulp-htmlmin');//压缩html
const scriptmin = require('gulp-uglify'); //引入js压缩模块
const gulp_minify_css = require('gulp-minify-css'); //压缩css
const concat = require('gulp-concat'); //引入合并代码模块
const babel = require('gulp-babel'); //引入ES6转ES5模块
const zip = require('gulp-zip');;//打包后压缩zip
const preprocess = require("gulp-preprocess"); //区分html,js环境变量
const plumber = require('gulp-plumber'); //阻止报错暂停
// const phpMinify = require('@aquafadas/gulp-php-minify'); // 压缩php文件
//const gulpless = require('gulp-less'); //引入less转换模块
//const imagemin = require('gulp-imagemin'); //引入图片压缩模块
// const rev = require('gulp-rev');//给静态文件资源添加hash值防缓存
//const browserSync = require('browser-sync').create(); //热更新模块
// 环境变量
const env = process.env.NODE_ENV === 'prediction' ? false : true
let target = env ? './dist/Art_Blog' : os.type() == 'Darwin' ? '/Applications/phpstudy/WWW/weipxiu.com/wp-content/themes/Art_Blog' : 'D:/PHPTutorial/WWW/wp-content/themes/Art_Blog'
// os.type() : Windows_NT、Darwin(系统)、Linux
console.log('打包环境: ' + (env ? '生产' : '测试') + ';系统: ' + (os.type() == 'Darwin' ? 'macOs' : 'windows'), '打包目标地址:' + target + '\n')
/* 对Date的扩展,将 Date 转化为指定格式的String
月(M)、日(d)、小时(h)、分(m)、秒(s)、季度(q) 可以用 1-2 个占位符,
年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字)
例子:
(new Date()).Format("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-02 08:09:04.423
(new Date()).Format("yyyy-M-d h:m:s.S") ==> 2006-7-2 8:9:4.18
*/
Date.prototype.Format = function (fmt) { // author: meizz
var o = {
"M+": this.getMonth() + 1, // 月份
"d+": this.getDate(), // 日
"h+": this.getHours(), // 小时
"m+": this.getMinutes(), // 分
"s+": this.getSeconds(), // 秒
"q+": Math.floor((this.getMonth() + 3) / 3), // 季度
"S": this.getMilliseconds() // 毫秒
};
if (/(y+)/.test(fmt))
fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
for (var k in o)
if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
return fmt;
}
//每次打包往首页追加打包时间信息
function writeFileToLine(ver, url) {
let data = fs.readFileSync(url, 'utf8').split(/\r\n|\n|\r/gm); //readFileSync的第一个参数是文件名
data[4] = `<meta name='generator' content='WordPress/Art_Blog v${new Date().Format("yyyy-MM-dd hh:mm:ss")}'>`;
fs.writeFileSync(url, data.join('\n'))
}
writeFileToLine('', './src/index.php')
/*
gulp.task -- 定义任务
gulp.src -- 找到需要执行任务的文件
gulp.dest -- 执行任务的文件的去处
gulp.watch -- 观察文件是否发生改变
安装gulpless压缩模块 npm i gulp-less --save-dev
执行任务 gulp + 任务名称 + 回车
*/
//清空dist目录
function clearFile() {
console.log('\n已成功清理' + target + '文件目录!!!!!!\n');
return del([target, "./Art_Blog.zip"], { force: true }); //force:允许删除当前工做目录和外部目录
}
// 拷贝文件
function copyHtml() {
//pipe后面对应的地址就是将前面路径文件拷贝复制到哪里去
console.log('\n正在打包编译中,请稍后......................\n');
return gulp.src(["src/**", "!src/*.html", "!src/js/*", "!src/css/*"]).pipe(gulp.dest(target))
}
//压缩html
function miniHtml() {
return gulp.src(['src/*.html'])
.pipe(preprocess({
context: {
// 此处可接受来自调用命令的 NODE_ENV 参数,默认为 development 开发测试环境
NODE_ENV: process.env.NODE_ENV || 'development',
},
}))
.pipe(htmlmin({
collapseWhitespace: true, // 折叠html节点间的空白
minifyCSS: true, // 压缩css
minifyJS: true, // 压缩js
removeComments: true, // 去除注释
removeEmptyAttributes: true, // 去除空属性
removeRedundantAttributes: true // 去除与默认属性一致的属性值
}))
.pipe(gulp.dest(target));
}
// 压缩css
function minCss() {
return gulp.src(["src/css/codecolorer.css", "src/css/swiper.min.css", "src/css/login.css", "src/css/style-admin.css"])
// .pipe(rev())//添加hash值防缓存
// .pipe(gulpless())
.pipe(gulp_minify_css({
advanced: false,//类型:Boolean 默认:true [是否开启高级优化(合并选择器等)]
compatibility: '*'//保留ie7及以下兼容写法 类型:String 默认:''or'*' [启用兼容模式; 'ie7':IE7兼容模式,'ie8':IE8兼容模式,'*':IE9+兼容模式]
}))
.pipe(gulp.dest(target + "/css"))
}
// 多端压缩合并css
function mergeCss() {
return gulp.src(["src/css/main.css", "src/css/style-pc.css", "src/css/style-ios.css", "src/css/style-ipd.css"])
.pipe(concat("style_min.css"))
.pipe(gulp_minify_css({
advanced: false,
compatibility: '*'
}))
.pipe(gulp.dest(target + "/css"))
}
// 压缩php
// function minPhp() {
// return gulp.src('src/*.php', {read: false})
// .pipe(phpMinify())
// .pipe(gulp.dest(target + "/css"))
// }
//图片压缩
//安装模块 npm install --save-dev gulp-imagemin
function imageMin() {
return gulp.src('src/images/*')
.pipe(imagemin([
imagemin.gifsicle({
interlaced: true
}),
imagemin.jpegtran({
progressive: true
}),
imagemin.optipng({
optimizationLevel: 7
}),
imagemin.svgo({
plugins: [{
removeViewBox: true
},
{
cleanupIDs: false
}]
})
]))
.pipe(gulp.dest(target + '/images'))
}
// js copy(插件及global)
function jsCopy() {
return gulp.src(["src/js/lib", "src/js/global.js"])
.pipe(gulp.dest(target + "/js"))
}
//ES6转换转ES5(babel-v8版本)、代码合并
//安装 npm i gulp-concat --save-dev
function jsConcat() {
return gulp.src(["src/js/main.js", "src/js/ajax_load.js"])
.pipe(plumber())
.pipe(babel({
presets: ['@babel/preset-env']
}))
.pipe(concat("main_min.js"))
.pipe(scriptmin()) //在合并的时候压缩js
.pipe(gulp.dest(target + "/js"))
}
//打包zip
function compressZip() {
return gulp.src(['./dist/**'])
.pipe(zip('Art_Blog.zip'))
.pipe(gulp.dest('./'));
}
//初始化browserSync
/*
function browser-sync(){
browserSync.init({
proxy: "http://127.0.0.1/",
port: 3000
});
}
*/
//监听文件是否发生改变
function Watch(cb) {
gulp.watch(["./src/css/codecolorer.css", "./src/css/swiper.min.css", "./src/css/login.css"], gulp.series(minCss));
gulp.watch(["./src/css/main.css", "./src/css/style-pc.css", "./src/css/style-ios.css", "./src/css/style-ipd.css"], gulp.series(mergeCss));
gulp.watch(["./src/js/global.js"], gulp.series(jsCopy));
gulp.watch(["./src/**/**.js", "!/src/js/global.js",], gulp.series(jsConcat));
gulp.watch(["./src/**", "!src/*.html", "!/src/js/*", "!/src/**.css"], gulp.series(copyHtml));
cb();
}
//"imageMin"不加入,否则打包太慢,图片压缩还是单独处理比较好
exports.default = gulp.series(clearFile, copyHtml, miniHtml, minCss, mergeCss, jsCopy, jsConcat, compressZip, Watch, function () {
console.log('\n恭喜您打包成功,文件存放目录' + target + '\n');
});