thinkphp整合系列之gulp實現前端自動化

這又是一個一次整合終身受益;不止是終身;換個項目一樣能夠很方便複用;不信你看另外一個項目: thinkphp整合系列之gulp實現前端自動化php

雖然我等叫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 奇才;未來維護程序猿界的正義與和平的重任就交給你了;
相關文章
相關標籤/搜索