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

简介: 这又是一个一次整合终身受益;不止是终身;换个项目同样可以很方便复用;不信你看另一个项目: thinkphp整合系列之gulp实现前端自动化虽然我等叫php程序猿;但是不可避免的是要跟ht...

这又是一个一次整合终身受益;不止是终身;换个项目同样可以很方便复用;不信你看另一个项目: 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": [ 
    "白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

如果不出意外;会自动编译并打开浏览器了;例如 thinkphp整合系列之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 奇才;将来维护程序猿界的正义与和平的重任就交给你了;

相关文章
|
2月前
|
JavaScript 前端开发 搜索推荐
Gulp:构建自动化与任务管理的强大工具
【10月更文挑战第13天】Gulp:构建自动化与任务管理的强大工具
84 0
|
缓存 JavaScript 前端开发
gulp安装教程(简单的前端自动化教程)
gulp安装教程(简单的前端自动化教程)
274 0
|
前端开发 JavaScript 程序员
【万字长文】通过grunt、gulp和fit,彻底搞懂前端的自动化构建(三)
【万字长文】通过grunt、gulp和fit,彻底搞懂前端的自动化构建
122 0
|
前端开发 JavaScript API
【万字长文】通过grunt、gulp和fit,彻底搞懂前端的自动化构建(二)
【万字长文】通过grunt、gulp和fit,彻底搞懂前端的自动化构建
248 0
|
移动开发 资源调度 前端开发
【万字长文】通过grunt、gulp和fit,彻底搞懂前端的自动化构建(一)
【万字长文】通过grunt、gulp和fit,彻底搞懂前端的自动化构建
148 0
|
JavaScript 前端开发 开发工具
从0搭建Vue3组件库:使用gulp自动化处理打包与发布
从0搭建Vue3组件库:使用gulp自动化处理打包与发布
604 0
|
缓存 资源调度 前端开发
说一说自动化构建以及Gulp
自动化构建是前端工程化当中的一个重要组成部分,自动化就是使用机器来代替人工来完成一些工作,构建我们可以将其理解为转换。总的来说就是将我们的源代码自动转换为生产环境当中可以运行的代码或程序。一般来说我们
157 0
说一说自动化构建以及Gulp
|
监控 前端开发 JavaScript
Gulp前端自动化构建工具的应用
实际前端开发不再仅仅是静态页面的开发了,丰富的前端技术让前端的代码逻辑越来越复杂, 模块化开发和各类框架也增加了在生产环境中部署开发环境代码的难度,这种情况下,前端自动化构建在前端开发中尤为重要。 我们会遇到下面的问题: a. 每次修改了HTML、JS、CSS等文件,都需要手动刷新浏览器,能不能修改了让浏览器自动刷新呢 ? b. 在发布项目的时候,需要将前端资源进行合并、压缩,尽量减少http请求,手动去完成合并压缩不仅繁琐,还容易出错,有什么技术可以自动地执行这些操作,解放我们的双手呢?
140 0
Gulp前端自动化构建工具的应用
|
Web App开发 设计模式 缓存
前端自动化构建之Gulp
本篇文章的核心是介绍一款强大的任务流工具Gulp,之所以题目叫做“前端自动化构建之Gulp”,是因为Gulp本身是使用JS编写的运行在Node环境的一个npm包,并且大部分开发者也都使用它来作为前端项目的自动化构建工具。不过,从本质上说,Gulp并非只能做前端自动化构建,后端构建发布自动化,脚本工具集自动化,测试流程自动化等都可以使用Gulp。所以,无论你是哪个技术栈的开发者,学习使用Gulp都会对你大有裨益。
163 0
|
JSON JavaScript 前端开发
【构建】gulp自动化构建工具入门教程
【构建】gulp自动化构建工具入门教程
153 0
【构建】gulp自动化构建工具入门教程
下一篇
DataWorks