thinkphp整合系列之gulp实现前端自动化

白俊遥博客
虽然我等叫php程序猿;
但是不可避免的是要跟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独立出来

另外;小伙子;我看你骨骼惊奇;必是 coding 奇才;
将来维护程序猿界的正义与和平的重任就交给你了;
我这有一系列文章;
原价13块8;现在免费送给你了;
各种传送门:
1. 前端自动化系列 (一) 之 node.js、npm、cnpm

2. 插播一篇 windows 下 git bash 命令行使用的文章

3. 前端自动化系列 (二) 之 less、scss、sass、stylus css 预处理器

4. 前端自动化系列 (三) 之 Babel、ES6、JavaScript 转码

5. 前端自动化系列 (四) 之 jade 预编译 html

6. 前端自动化系列 (五) 之 Browsersync 自动刷新

7 .前端自动化系列 (六) 之 gulp 自动化构建工具

白俊遥博客
请先登录后发表评论
  • latest comments
  • 总共35条评论
白俊遥博客

mr liu :项目运行gulpError: Cannot find module '@babel/core'    at Function.Module._resolveFilename (internal/modules/cjs/loader.js:581:15)    at Function.Module._load (internal/modules/cjs/loader.js:507:25)    at Module.require (internal/modules/cjs/loader.js:637:17)    at require (internal/modules/cjs/helpers.js:22:18)    at Object. (E:\thinkbjy\node_modules\gulp-babel\index.js:7:15)    at Module._compile (internal/modules/cjs/loader.js:689:30)    at Object.Module._extensions..js (internal/modules/cjs/loader.js:700:10)    at Module.load (internal/modules/cjs/loader.js:599:32)    at tryModuleLoad (internal/modules/cjs/loader.js:538:12)    at Function.Module._load (internal/modules/cjs/loader.js:530:3)

2019-02-21 11:42:41 回复

白俊遥博客

爱便流通于世 白俊遥博客

2017-06-21 23:46:11 回复

白俊遥博客

爱便流通于世 :白哥!// 监听其他不编译的文件 有变化直接copy    gulp.watch(src+'/**/*.!(jpg|jpeg|png|gif|bmp|scss|js|html)', ['copy']); 删除文件却没有自动刷新 有破解之法吗?

2017-06-21 22:45:43 回复

白俊遥博客

repair77 :啦啦阿拉

2017-06-15 18:14:43 回复

白俊遥博客

轩辕天2015 :求所有函数命令

2017-04-12 11:02:12 回复

白俊遥博客

青栀xy520 :挺好的

2017-04-05 17:12:02 回复

白俊遥博客

远行 :内容页的分类链接不对的~

2017-03-29 17:58:31 回复

白俊遥博客

远行 白俊遥博客

2017-03-27 16:27:50 回复

白俊遥博客

Kody 白俊遥博客白俊遥博客

2017-03-15 15:51:01 回复

白俊遥博客

Miss 小林" :不知道为什么我运行之后压缩是压缩了    命令行出现了:Options to be implemented,但是运行你的是没问题的

2017-03-11 22:38:47 回复

白俊遥博客

细水韶年 白俊遥博客

2017-03-07 11:59:41 回复

白俊遥博客

阿迪 :博主好,我是郑州的。目前正在开发thinkphp项目。想看看和你有合作的地方。方便加个我QQ吗?邮箱是我的Q地址。谢谢啊

2017-03-02 20:09:55 回复

白俊遥博客

WP花园-西瓜 :name: 

2017-02-21 13:33:18 回复

白俊遥博客

24.hour_zzZ :作为一个phper,面对一扎的前端工具一脸懵逼。万分感谢楼主帮在下打通任督二脉。

2017-01-22 00:01:46 回复

白俊遥博客

Templet360 白俊遥博客

2017-01-08 22:27:37 回复

白俊遥博客

黑马白狼 :请先登录后回复评论

2017-01-20 15:47:41 回复

白俊遥博客

い物雨星空つ 白俊遥博客

2017-03-18 21:37:01 回复

白俊遥博客

い物雨星空つ 白俊遥博客

2017-03-18 21:37:03 回复

白俊遥博客

い物雨星空つ 白俊遥博客

2017-03-18 21:37:04 回复

白俊遥博客

い物雨星空つ 白俊遥博客

2017-03-18 21:37:05 回复

白俊遥博客

い物雨星空つ 白俊遥博客

2017-03-18 21:37:24 回复

白俊遥博客

Templet360 :确实很厉害

2017-01-08 13:16:55 回复

白俊遥博客

吴伟祥 :今晚把php部分全部看完!真刺激!

2017-01-06 18:21:06 回复

白俊遥博客 白俊遥博客

云淡风晴 :你开心就好;

2017-01-07 10:59:15 回复

白俊遥博客

php土豆 :1

2017-01-04 20:41:44 回复

白俊遥博客

php土豆 :博客很不错

2017-01-04 20:41:36 回复

白俊遥博客 白俊遥博客

云淡风晴 :谢谢;

2017-01-07 10:59:25 回复

白俊遥博客

null :恭喜结课  大致懂了 对 大致

2017-01-04 15:42:18 回复

白俊遥博客 白俊遥博客

云淡风晴 :大致是谁?

2017-01-07 10:59:46 回复

白俊遥博客

步入中年的一条汪 白俊遥博客厉害... 然而我看这些还是一脸懵逼 还需努力...

2017-01-03 15:17:37 回复

白俊遥博客

{"name":"路人黄"} 白俊遥博客

2017-01-04 01:04:19 回复

白俊遥博客

{"name":"路人黄"} 白俊遥博客

2017-01-04 01:04:33 回复

白俊遥博客

岁月如歌___cmy :厉害了

2017-01-03 10:50:53 回复

白俊遥博客

{"name":"路人黄"} 白俊遥博客

2017-01-04 01:04:05 回复

白俊遥博客

♔ゞ小帅ㄣ♔ 白俊遥博客

2017-04-17 14:07:56 回复