作者寄语:
thinkphp整合系列之gulp实现前端自动化
但是不可避免的是要跟html打交道的;
而且php这么容易开发web;
难道我们不想自己随手写点什么?
laravel这类比较前卫的框架;
早就深度集成了很多前端的东西;
现在;就让我们手动为thinkphp也插上gulp的翅膀吧;
第一步;在自己的thinkphp项目根目录中创建 package.json;
{
"name": "baijunyao/thinkphp-bjyadmin",
"version": "1.0.0",
"description": "白俊遥博客",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"keywords": [
"白俊遥",
"博客"
],
"author": "baijunyao",
"license": "Apache2",
"devDependencies": {
"babel-preset-es2015": "^6.18.0",
"babel-preset-stage-2": "^6.18.0",
"browser-sync": "^2.14.0",
"gulp": "^3.9.1",
"gulp-babel": "^6.1.2",
"gulp-cleanhtml": "^1.0.1",
"gulp-concat": "^2.6.0",
"gulp-contrib-copy": "^0.1.2",
"gulp-decomment": "^0.1.3",
"gulp-imagemin": "^3.0.2",
"gulp-less": "^3.1.0",
"gulp-load-plugins": "^1.2.4",
"gulp-minify-css": "^1.2.4",
"gulp-plumber": "^1.1.0",
"gulp-rename": "^1.2.2",
"gulp-sass": "^2.3.2",
"gulp-uglify": "^2.0.0"
}
}
第二步;在自己的thinkphp项目根目录中创建 gulpfile.js;var gulp = require('gulp'),
sass = require('gulp-sass'),
minifyCss = require('gulp-minify-css'),
plumber = require('gulp-plumber'),
babel = require('gulp-babel'),
uglify = require('gulp-uglify'),
clearnHtml = require("gulp-cleanhtml"),
imagemin = require('gulp-imagemin'),
copy = require('gulp-contrib-copy'),
browserSync = require('browser-sync').create(),
reload = browserSync.reload;
// 定义源代码的目录和编译压缩后的目录
var src='tpl_src',
dist='tpl';
// 编译全部scss 并压缩
gulp.task('css', function(){
gulp.src(src+'/**/*.scss')
.pipe(sass())
.pipe(minifyCss())
.pipe(gulp.dest(dist))
})
// 编译全部js 并压缩
gulp.task('js', function() {
gulp.src(src+'/**/*.js')
.pipe(plumber())
.pipe(babel({
presets: ['es2015']
}))
.pipe(uglify())
.pipe(gulp.dest(dist));
});
// 压缩全部html
gulp.task('html', function () {
gulp.src(src+'/**/*.+(html|tpl)')
.pipe(clearnHtml())
.pipe(gulp.dest(dist));
});
// 压缩全部image
gulp.task('image', function () {
gulp.src([src+'/**/*.+(jpg|jpeg|png|gif|bmp)'])
.pipe(imagemin())
.pipe(gulp.dest(dist));
});
// 其他不编译的文件直接copy
gulp.task('copy', function () {
gulp.src(src+'/**/*.!(jpg|jpeg|png|gif|bmp|scss|js|html|tpl)')
.pipe(copy())
.pipe(gulp.dest(dist));
});
// 自动刷新
gulp.task('server', function() {
browserSync.init({
proxy: "tbjyadmin.com", // 指定代理url
notify: false, // 刷新不弹出提示
});
// 监听scss文件编译
gulp.watch(src+'/**/*.scss', ['css']);
// 监听其他不编译的文件 有变化直接copy
gulp.watch(src+'/**/*.!(jpg|jpeg|png|gif|bmp|scss|js|html)', ['copy']);
// 监听html文件变化后刷新页面
gulp.watch(src+"/**/*.js", ['js']).on("change", reload);
// 监听html文件变化后刷新页面
gulp.watch(src+"/**/*.+(html|tpl)", ['html']).on("change", reload);
// 监听css文件变化后刷新页面
gulp.watch(dist+"/**/*.css").on("change", reload);
});
// 监听事件
gulp.task('default', ['css', 'js', 'image', 'html', 'copy', 'server'])
把 gulpfile.js 中的src 和 dist 变量替换为自己项目的实际目录;把proxy 替换为自己的本地自定义域名;
第三步: 命令行运行如下命令:
# 安装各种包
cnpm install
# 运行gulp
gulp
如果不出意外;会自动编译并打开浏览器了;很简单吧;就3步;
但是为了写这篇文章;
我花了2个月时间写了7篇文章做铺垫;
想想;我的内心都是崩溃的;
以项目为例讲解下吧: https://github.com/baijunyao/thinkphp-bjyadmin
运行gulp后;会有如下操作;
1. tpl_src 目录下的所有scss文件编译压缩输出到 src 目录下;
2. tpl_src 目录下的所有js使用babel转码压缩输出到 src 目录下;
3. tpl_src 目录下的所有图片压缩输出到 src 目录下;
4. tpl_src 目录下的所有html压缩输出到src目录下;
5. tpl_src 目录下的其他类型文件直接复制到src目录下;
6. 触发监听任务;有文件变动自动执行上述几条任务;并且自动刷新浏览器;
这又是一个一次整合终身受益;
不止是终身;换个项目同样可以很方便复用;
不信你看另一个项目: https://github.com/baijunyao/thinkphp-bjyblog
神马?你的html和各种静态文件还都放在Application的各个模块下的view目录中?
那先来看这篇文章:thinkphp把模板文件View独立出来http://baijunyao.com/article/90
另外;小伙子;我看你骨骼惊奇;必是 coding 奇才;
将来维护程序猿界的正义与和平的重任就交给你了;
我这有一系列文章;
原价13块8;现在免费送给你了;
各种传送门:
1. 前端自动化系列 (一) 之 node.js、npm、cnpm http://baijunyao.com/article/93
2. 插播一篇 windows 下 git bash 命令行使用的文章 http://baijunyao.com/article/94
3. 前端自动化系列 (二) 之 less、scss、sass、stylus css 预处理器 http://baijunyao.com/article/95
4. 前端自动化系列 (三) 之 Babel、ES6、ja
5. 前端自动化系列 (四) 之 jade 预编译 html http://baijunyao.com/article/97
6. 前端自动化系列 (五) 之 Browsersync 自动刷新 http://baijunyao.com/article/101
7 .前端自动化系列 (六) 之 gulp 自动化构建工具 http://baijunyao.com/article/102
本文为白俊遥原创文章, 转载无需和我联系, 但请注明来自白俊遥博客 http://baijunyao.com/article/103