摘要:自動(dòng)化構(gòu)建工具使用簡言現(xiàn)在不管是做前端還是后端的,不可避免的是要跟打交道的而且這么容易開發(fā)難道我們不想自己隨手寫點(diǎn)什么這類比較前衛(wèi)的框架早就深度集成了很多前端的東西現(xiàn)在,就讓我們手動(dòng)為也插上的翅膀吧。
gulp自動(dòng)化構(gòu)建工具使用 簡言
現(xiàn)在不管是做前端還是后端的,不可避免的是要跟html打交道的;而且Node這么容易開發(fā)web;難道我們不想自己隨手寫點(diǎn)什么?Express這類比較前衛(wèi)的框架;早就深度集成了很多前端的東西;現(xiàn)在,就讓我們手動(dòng)為thinkphp也插上gulp的翅膀吧。構(gòu)建 第一步
在自己的thinkphp項(xiàng)目根目錄中創(chuàng)建 package.json;加上以下依賴
{ "name": "baijunyao/thinkphp-bjyadmin", "version": "1.0.0", "description": "WebLSS博客", "main": "index.js", "scripts": { "test": "echo "Error: no test specified" && exit 1" }, "keywords": [ "WebLSS", "博客" ], "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" } }第二步
創(chuàng)建gulpfile.js文件
/** * Created by WebLss on 2018/8/3 */ var gulp = require("gulp") var sass = require("gulp-sass") var minifyCss = require("gulp-minify-css") var plumber = require("gulp-plumber") var babel = require("gulp-babel") var uglify = require("gulp-uglify") var clearnHtml = require("gulp-cleanhtml") var imagemin = require("gulp-imagemin") var copy = require("gulp-contrib-copy") var browserSync = require("browser-sync").create() var reload = browserSync.reload // 定義源代碼的目錄和編譯壓縮后的目錄 var src = "public/src" var dist = "public/dist" var viewSrc = "views/src" var viewDist = "views/dist" // 編譯全部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|ejs)") .pipe(clearnHtml()) .pipe(gulp.dest(dist)) // 編譯視圖文件 gulp.src(viewSrc + "/**/*.+(html|ejs)") .pipe(clearnHtml()) .pipe(gulp.dest(viewDist)) }) // 壓縮全部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|ejs)") .pipe(copy()) .pipe(gulp.dest(dist)) }) // 自動(dòng)刷新 gulp.task("server", function () { browserSync.init({ proxy: "veekergdn.com", // 指定代理url notify: false // 刷新不彈出提示 }) // 監(jiān)聽scss文件編譯 gulp.watch(src + "/**/*.scss", ["css"]) // 監(jiān)聽其他不編譯的文件 有變化直接copy gulp.watch(src + "/**/*.!(jpg|jpeg|png|gif|bmp|scss|js|html)", ["copy"]) // 監(jiān)聽html文件變化后刷新頁面 gulp.watch(src + "/**/*.js", ["js"]).on("change", reload) // 監(jiān)聽html文件變化后刷新頁面 gulp.watch(src + "/**/*.+(html|ejs)", ["html"]).on("change", reload) // 監(jiān)聽css文件變化后刷新頁面 gulp.watch(dist + "/**/*.css").on("change", reload) }) // 監(jiān)聽事件 gulp.task("default", ["css", "js", "image", "html", "copy", "server"])
把 gulpfile.js 中的src 和 dist 變量替換為自己項(xiàng)目的實(shí)際目錄;
把proxy 替換為自己的本地自定義域名;
第三步: 命令行運(yùn)行如下命令:
cnpm install 或npm install
運(yùn)行g(shù)ulpgulp
如果不出意外;會(huì)自動(dòng)編譯并打開瀏覽器了;
很簡單吧;就3步;
以項(xiàng)目為例講解下吧: https://github.com/WebLss/Nod...
運(yùn)行g(shù)ulp后;會(huì)有如下操作;
1.src目錄下的圖片、文件、html、scss都會(huì)編譯到view_dist目錄 2.可以手動(dòng)設(shè)置開發(fā)階段使用src/dist目錄的html頁面,`product`和`development` 兩個(gè)狀態(tài)切換 3.觸發(fā)監(jiān)聽任務(wù),有文件變動(dòng)自動(dòng)執(zhí)行上述幾條任務(wù),并且自動(dòng)刷新瀏覽器, 這又是一個(gè)一次整合終身受益,不止是終身;換個(gè)項(xiàng)目同樣可以很方便復(fù)用;意義
估計(jì)大家也都看出來了,為什么要用gulp編譯壓縮,無非就是有效利用空間資源,優(yōu)化加載速度,優(yōu)化網(wǎng)站性能,提升用戶體驗(yàn)感
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/19352.html
摘要:本項(xiàng)目持續(xù)更新中,開源免費(fèi)與各位愛好技術(shù)達(dá)人共勉,注現(xiàn)階段仍在開發(fā)中。。。。。 NodeJS+Express+MongoDb開發(fā)的個(gè)人博客 NodeJS+Express搭建個(gè)人博客-環(huán)境搭建(一)NodeJS+Express搭建個(gè)人博客-gulp自動(dòng)化構(gòu)建工具使用(二)NodeJS+Express搭建個(gè)人博客-Express+Mongodb組合架構(gòu)介紹(三)NodeJS+Express...
摘要:博主目前的這個(gè)項(xiàng)目還不算很大,模塊依賴簡單,但期望完成諸如版本號(hào)替換,壓縮代碼,合并文件,發(fā)布到服務(wù)器等和模塊化關(guān)系不大的工作,所以使用了。同時(shí),對和附加緩存,配合和版本號(hào)實(shí)現(xiàn)服務(wù)器更新,這一部分其實(shí)已經(jīng)幫我們實(shí)現(xiàn)好了。 經(jīng)常在各種論壇、博客還有 github 上活躍的朋友不難發(fā)現(xiàn),許多大牛都有自己的網(wǎng)站,也多以博客為主。博主作為一個(gè)立志前端的大白,難道不應(yīng)該和大牛學(xué)習(xí)么?說干就干,前...
摘要:博主目前的這個(gè)項(xiàng)目還不算很大,模塊依賴簡單,但期望完成諸如版本號(hào)替換,壓縮代碼,合并文件,發(fā)布到服務(wù)器等和模塊化關(guān)系不大的工作,所以使用了。同時(shí),對和附加緩存,配合和版本號(hào)實(shí)現(xiàn)服務(wù)器更新,這一部分其實(shí)已經(jīng)幫我們實(shí)現(xiàn)好了。 經(jīng)常在各種論壇、博客還有 github 上活躍的朋友不難發(fā)現(xiàn),許多大牛都有自己的網(wǎng)站,也多以博客為主。博主作為一個(gè)立志前端的大白,難道不應(yīng)該和大牛學(xué)習(xí)么?說干就干,前...
摘要:沒有耐心閱讀的同學(xué),可以直接前往學(xué)習(xí)全棧最后一公里。我下面會(huì)羅列一些,我自己錄制過的一些項(xiàng)目,或者其他的我覺得可以按照這個(gè)路線繼續(xù)深入學(xué)習(xí)的項(xiàng)目資源。 showImg(https://segmentfault.com/img/bVMlke?w=833&h=410); 本文技術(shù)軟文,閱讀需謹(jǐn)慎,長約 7000 字,通讀需 5 分鐘 大家好,我是 Scott,本文通過提供給大家學(xué)習(xí)的方法,...
閱讀 2901·2021-11-22 09:34
閱讀 1223·2021-11-19 09:40
閱讀 3349·2021-10-14 09:43
閱讀 3578·2021-09-23 11:22
閱讀 1612·2021-08-31 09:39
閱讀 894·2019-08-30 15:55
閱讀 1422·2019-08-30 15:54
閱讀 864·2019-08-30 15:53