最新赞助活动温馨提示:自愿赞助服务器费用,学生和没有工作的整站资源免费下载!
头像

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

来源:http://erdangjiade.com/php/2664.html 沐浴春风 2017-05-25 15:41浏览(1763)

这又是一个一次整合终身受益;不止是终身;换个项目同样可以很方便复用; 不信你看另一个项目: thinkphp整合系列之gulp实现前端自动化

0、请不要问“在不在”之类的问题,有问题直接问!1、学生或暂时没有工作的童鞋,整站资源免费下载!2、¥9.9充值终身VIP会员,加我微信,826096331 拉你进VIP群学习!3、程序员加油,技术改变世界。 在线 充值

thinkphp整合系列之gulp实现前端自动化
分类:PHP > Thinkphp 难易:高级
查看演示 下载资源:

加我微信,拉你进VIP群学习:

下载资源 下载积分: 200 积分

虽然我等叫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": [
    "白666",
    "博客"
  ],
  "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篇文章做铺垫; 想想;我的内心都是崩溃的; 以项目为例讲解下吧: 运行gulp后;会有如下操作; tpl_src 目录下的所有scss文件编译压缩输出到 src 目录下; tpl_src 目录下的所有js使用babel转码压缩输出到 src 目录下; tpl_src 目录下的所有图片压缩输出到 src 目录下; tpl_src 目录下的所有html压缩输出到src目录下; tpl_src 目录下的其他类型文件直接复制到src目录下; 触发监听任务;有文件变动自动执行上述几条任务;并且自动刷新浏览器; 神马?你的html和各种静态文件还都放在Application的各个模块下的view目录中? 那先来看这篇文章:thinkphp把模板文件View独立出来 另外;小伙子;我看你骨骼惊奇;必是 coding 奇才; 将来维护程序猿界的正义与和平的重任就交给你了;

声明:本文为原创文章,如需转载,请注明来源erdangjiade.com并保留原文链接:https://www.erdangjiade.com/php/2664.html
评论5
头像

友情提示:垃圾评论一律封号 加我微信:826096331拉你进VIP群学习群

  • 头像 4楼
    09-26 09:16
    昵称
    没怎么看太明白。<br />
  • 头像 3楼
    08-22 08:09
    昵称
    怎么演示不了?
  • 头像 板凳
    07-22 15:30
    EXCEPTION
    白俊遥大神
  • 头像 椅子
    06-02 11:25
    lansai
    太棒了,终于找到了
  • 头像 沙发
    05-27 21:55
    keysarjan
    想学习 。。。。。。。。。。。。。
1 2