国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

NodeJS+Express搭建個人博客-gulp自動化構建工具使用(二)

Yangder / 2460人閱讀

摘要:自動化構建工具使用簡言現(xiàn)在不管是做前端還是后端的,不可避免的是要跟打交道的而且這么容易開發(fā)難道我們不想自己隨手寫點什么這類比較前衛(wèi)的框架早就深度集成了很多前端的東西現(xiàn)在,就讓我們手動為也插上的翅膀吧。

gulp自動化構建工具使用 簡言

</>復制代碼

  1. 現(xiàn)在不管是做前端還是后端的,不可避免的是要跟html打交道的;而且Node這么容易開發(fā)web;難道我們不想自己隨手寫點什么?Express這類比較前衛(wèi)的框架;早就深度集成了很多前端的東西;現(xiàn)在,就讓我們手動為thinkphp也插上gulp的翅膀吧。
構建 第一步

在自己的thinkphp項目根目錄中創(chuàng)建 package.json;加上以下依賴

</>復制代碼

  1. {
  2. "name": "baijunyao/thinkphp-bjyadmin",
  3. "version": "1.0.0",
  4. "description": "WebLSS博客",
  5. "main": "index.js",
  6. "scripts": {
  7. "test": "echo "Error: no test specified" && exit 1"
  8. },
  9. "keywords": [
  10. "WebLSS",
  11. "博客"
  12. ],
  13. "author": "baijunyao",
  14. "license": "Apache2",
  15. "devDependencies": {
  16. "babel-preset-es2015": "^6.18.0",
  17. "babel-preset-stage-2": "^6.18.0",
  18. "browser-sync": "^2.14.0",
  19. "gulp": "^3.9.1",
  20. "gulp-babel": "^6.1.2",
  21. "gulp-cleanhtml": "^1.0.1",
  22. "gulp-concat": "^2.6.0",
  23. "gulp-contrib-copy": "^0.1.2",
  24. "gulp-decomment": "^0.1.3",
  25. "gulp-imagemin": "^3.0.2",
  26. "gulp-less": "^3.1.0",
  27. "gulp-load-plugins": "^1.2.4",
  28. "gulp-minify-css": "^1.2.4",
  29. "gulp-plumber": "^1.1.0",
  30. "gulp-rename": "^1.2.2",
  31. "gulp-sass": "^2.3.2",
  32. "gulp-uglify": "^2.0.0"
  33. }
  34. }
第二步

創(chuàng)建gulpfile.js文件

</>復制代碼

  1. /**
  2. * Created by WebLss on 2018/8/3
  3. */
  4. var gulp = require("gulp")
  5. var sass = require("gulp-sass")
  6. var minifyCss = require("gulp-minify-css")
  7. var plumber = require("gulp-plumber")
  8. var babel = require("gulp-babel")
  9. var uglify = require("gulp-uglify")
  10. var clearnHtml = require("gulp-cleanhtml")
  11. var imagemin = require("gulp-imagemin")
  12. var copy = require("gulp-contrib-copy")
  13. var browserSync = require("browser-sync").create()
  14. var reload = browserSync.reload
  15. // 定義源代碼的目錄和編譯壓縮后的目錄
  16. var src = "public/src"
  17. var dist = "public/dist"
  18. var viewSrc = "views/src"
  19. var viewDist = "views/dist"
  20. // 編譯全部scss 并壓縮
  21. gulp.task("css", function () {
  22. gulp.src(src + "/**/*.scss")
  23. .pipe(sass())
  24. .pipe(minifyCss())
  25. .pipe(gulp.dest(dist))
  26. })
  27. // 編譯全部js 并壓縮
  28. gulp.task("js", function () {
  29. gulp.src(src + "/**/*.js")
  30. .pipe(plumber())
  31. .pipe(babel({
  32. presets: ["es2015"]
  33. }))
  34. .pipe(uglify())
  35. .pipe(gulp.dest(dist))
  36. })
  37. // 壓縮全部html
  38. gulp.task("html", function () {
  39. gulp.src(src + "/**/*.+(html|ejs)")
  40. .pipe(clearnHtml())
  41. .pipe(gulp.dest(dist))
  42. // 編譯視圖文件
  43. gulp.src(viewSrc + "/**/*.+(html|ejs)")
  44. .pipe(clearnHtml())
  45. .pipe(gulp.dest(viewDist))
  46. })
  47. // 壓縮全部image
  48. gulp.task("image", function () {
  49. gulp.src([src + "/**/*.+(jpg|jpeg|png|gif|bmp)"])
  50. .pipe(imagemin())
  51. .pipe(gulp.dest(dist))
  52. })
  53. // 其他不編譯的文件直接copy
  54. gulp.task("copy", function () {
  55. gulp.src(src + "/**/*.!(jpg|jpeg|png|gif|bmp|scss|js|html|ejs)")
  56. .pipe(copy())
  57. .pipe(gulp.dest(dist))
  58. })
  59. // 自動刷新
  60. gulp.task("server", function () {
  61. browserSync.init({
  62. proxy: "veekergdn.com", // 指定代理url
  63. notify: false // 刷新不彈出提示
  64. })
  65. // 監(jiān)聽scss文件編譯
  66. gulp.watch(src + "/**/*.scss", ["css"])
  67. // 監(jiān)聽其他不編譯的文件 有變化直接copy
  68. gulp.watch(src + "/**/*.!(jpg|jpeg|png|gif|bmp|scss|js|html)", ["copy"])
  69. // 監(jiān)聽html文件變化后刷新頁面
  70. gulp.watch(src + "/**/*.js", ["js"]).on("change", reload)
  71. // 監(jiān)聽html文件變化后刷新頁面
  72. gulp.watch(src + "/**/*.+(html|ejs)", ["html"]).on("change", reload)
  73. // 監(jiān)聽css文件變化后刷新頁面
  74. gulp.watch(dist + "/**/*.css").on("change", reload)
  75. })
  76. // 監(jiān)聽事件
  77. gulp.task("default", ["css", "js", "image", "html", "copy", "server"])

把 gulpfile.js 中的src 和 dist 變量替換為自己項目的實際目錄;
把proxy 替換為自己的本地自定義域名;
第三步: 命令行運行如下命令:

安裝各種包

cnpm install 或npm install

運行gulp

gulp
如果不出意外;會自動編譯并打開瀏覽器了;
很簡單吧;就3步;
以項目為例講解下吧: https://github.com/WebLss/Nod...
運行gulp后;會有如下操作;

</>復制代碼

  1. 1.src目錄下的圖片、文件、htmlscss都會編譯到view_dist目錄
  2. 2.可以手動設置開發(fā)階段使用src/dist目錄的html頁面,`product``development`
  3. 兩個狀態(tài)切換
  4. 3.觸發(fā)監(jiān)聽任務,有文件變動自動執(zhí)行上述幾條任務,并且自動刷新瀏覽器,
  5. 這又是一個一次整合終身受益,不止是終身;換個項目同樣可以很方便復用;
意義

估計大家也都看出來了,為什么要用gulp編譯壓縮,無非就是有效利用空間資源,優(yōu)化加載速度,優(yōu)化網(wǎng)站性能,提升用戶體驗感

文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/19352.html

相關文章

  • NodeJS+Express搭建個人博客-環(huán)境搭建(一)

    摘要:本項目持續(xù)更新中,開源免費與各位愛好技術達人共勉,注現(xiàn)階段仍在開發(fā)中。。。。。 NodeJS+Express+MongoDb開發(fā)的個人博客 NodeJS+Express搭建個人博客-環(huán)境搭建(一)NodeJS+Express搭建個人博客-gulp自動化構建工具使用(二)NodeJS+Express搭建個人博客-Express+Mongodb組合架構介紹(三)NodeJS+Express...

    Clect 評論0 收藏0
  • 個人博客主頁搭建隨筆

    摘要:博主目前的這個項目還不算很大,模塊依賴簡單,但期望完成諸如版本號替換,壓縮代碼,合并文件,發(fā)布到服務器等和模塊化關系不大的工作,所以使用了。同時,對和附加緩存,配合和版本號實現(xiàn)服務器更新,這一部分其實已經(jīng)幫我們實現(xiàn)好了。 經(jīng)常在各種論壇、博客還有 github 上活躍的朋友不難發(fā)現(xiàn),許多大牛都有自己的網(wǎng)站,也多以博客為主。博主作為一個立志前端的大白,難道不應該和大牛學習么?說干就干,前...

    whjin 評論0 收藏0
  • 個人博客主頁搭建隨筆

    摘要:博主目前的這個項目還不算很大,模塊依賴簡單,但期望完成諸如版本號替換,壓縮代碼,合并文件,發(fā)布到服務器等和模塊化關系不大的工作,所以使用了。同時,對和附加緩存,配合和版本號實現(xiàn)服務器更新,這一部分其實已經(jīng)幫我們實現(xiàn)好了。 經(jīng)常在各種論壇、博客還有 github 上活躍的朋友不難發(fā)現(xiàn),許多大牛都有自己的網(wǎng)站,也多以博客為主。博主作為一個立志前端的大白,難道不應該和大牛學習么?說干就干,前...

    cnio 評論0 收藏0
  • 全棧最后一公里 - Node.js 項目的線上服務器部署與發(fā)布

    摘要:沒有耐心閱讀的同學,可以直接前往學習全棧最后一公里。我下面會羅列一些,我自己錄制過的一些項目,或者其他的我覺得可以按照這個路線繼續(xù)深入學習的項目資源。 showImg(https://segmentfault.com/img/bVMlke?w=833&h=410); 本文技術軟文,閱讀需謹慎,長約 7000 字,通讀需 5 分鐘 大家好,我是 Scott,本文通過提供給大家學習的方法,...

    Nosee 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<