自動化構建工具gulp簡單介紹及使用

来源:http://www.cnblogs.com/diasa-fly/archive/2017/04/15/6714486.html
-Advertisement-
Play Games

一、簡介及安裝: gulp是前端開發過程中對代碼進行構建的工具,是自動化項目的構建利器;她不僅能對網站資源進行優化,而且在開發過程中很多重覆的任務能夠使用正確的工具自動完成;使用她,我們不僅可以很愉快的編寫代碼,而且大大提高我們的工作效率 gulp的優點:基於流的操作、任務化。 常用api:src ...


一、簡介及安裝:

  gulp是前端開發過程中對代碼進行構建的工具,是自動化項目的構建利器;她不僅能對網站資源進行優化,而且在開發過程中很多重覆的任務能夠使用正確的工具自動完成;使用她,我們不僅可以很愉快的編寫代碼,而且大大提高我們的工作效率

gulp的優點:基於流的操作任務化

 

常用api:src 、dest、watch、task、pipe

由於gulp是基於node的所以使用的時候需要通過npm或者cnpm安裝全局安裝(cnpm i -g gulp)

常用的gulp需要安裝的包括gulp-clean   gulp-connect   gulp-concat    gulp-cssmin    gulp-imagemin    gulp-less  gulp-load-plugins  gulp-uglify  open

安裝以上的gulp插件可以使用cnpm i --save-dev xxx(--save-dev可以使安裝的插件的依賴保存在package.json中),同時有一種快捷的方式可以一次性安裝多個,每個組件之間使用空格隔開cnpm i --save-dev gulp-concat gulp-connect等

安裝完以上插件,package.json的文件會添加下麵的依賴。

二、使用

  首先需要創建一個gulpfile.js文件,使用require引入gulp模塊,同時引入gulp-load-plugins模塊(引入該模塊的目的是為了當以後想要引入gulp-connect等插件的時候,可以通過$直接引入,這樣比較方便

      下麵結合具體的實例對以上進行說明:(具體的已經給出註釋說明)

  

 1 var gulp = require('gulp');
 2 //引入gulp-load-plugins模塊 註意要將其實例化
 3 var $ = require('gulp-load-plugins')();
 4 var open = require('open');
 5 
 6 var app = {
 7   srcPath: 'src/',
 8   devPath: 'build/',
 9   prdPath: 'dist/'
10 };
11 
12 gulp.task('lib', function() {
13   gulp.src('bower_components/**/*.js')//讀取文件目錄
14   .pipe(gulp.dest(app.devPath + 'vendor'))//寫入目錄
15   .pipe(gulp.dest(app.prdPath + 'vendor'))
16   .pipe($.connect.reload());//重新刷新瀏覽器
17 });
18 
19 gulp.task('html', function() {
20   gulp.src(app.srcPath + '**/*.html')
21   .pipe(gulp.dest(app.devPath))
22   .pipe(gulp.dest(app.prdPath))
23   .pipe($.connect.reload());
24 })
25 
26 
27 gulp.task('json', function() {
28   gulp.src(app.srcPath + 'data/**/*.json')
29   .pipe(gulp.dest(app.devPath + 'data'))
30   .pipe(gulp.dest(app.prdPath + 'data'))
31   .pipe($.connect.reload());
32 });
33 
34 gulp.task('less', function() {
35   gulp.src(app.srcPath + 'style/index.less')
36   .pipe($.plumber())
37   .pipe($.less())//編譯less文件
38   .pipe(gulp.dest(app.devPath + 'css'))
39   .pipe($.cssmin())//壓縮css文件
40   .pipe(gulp.dest(app.prdPath + 'css'))
41   .pipe($.connect.reload());
42 });
43 
44 gulp.task('js', function() {
45   gulp.src(app.srcPath + 'script/**/*.js')
46   .pipe($.plumber())
47   .pipe($.concat('index.js'))//將js文件合併到index.js文件中
48   .pipe(gulp.dest(app.devPath + 'js'))
49   .pipe($.uglify())//壓縮js文件
50   .pipe(gulp.dest(app.prdPath + 'js'))
51   .pipe($.connect.reload());
52 });
53 
54 gulp.task('image', function() {
55   gulp.src(app.srcPath + 'image/**/*')
56   //捕獲處理任務中的錯誤
57   .pipe($.plumber())
58   .pipe(gulp.dest(app.devPath + 'image'))
59   .pipe($.imagemin())//壓縮圖片文件
60   .pipe(gulp.dest(app.prdPath + 'image'))
61   .pipe($.connect.reload());
62 });
63 //總的任務
64 gulp.task('build', ['image', 'js', 'less', 'lib', 'html', 'json']);
65 //清除目錄中的內容
66 gulp.task('clean', function() {
67   gulp.src([app.devPath, app.prdPath])
68   .pipe($.clean());
69 });
70 
71 gulp.task('serve', ['build'], function() {
72   $.connect.server({
73     root: [app.devPath],//讀取路徑
74     livereload: true,//自動刷新
75     port: 3000
76   });
77   //打開預設地址
78   open('http://localhost:3000');
79   //監控文件 當變化時執行相對應的任務
80   gulp.watch('bower_components/**/*', ['lib']);
81   gulp.watch(app.srcPath + '**/*.html', ['html']);
82   gulp.watch(app.srcPath + 'data/**/*.json', ['json']);
83   gulp.watch(app.srcPath + 'style/**/*.less', ['less']);
84   gulp.watch(app.srcPath + 'script/**/*.js', ['js']);
85   gulp.watch(app.srcPath + 'image/**/*', ['image']);
86 });
87 
88 gulp.task('default', ['serve']);
View Code

由於剛開通博客,不怎麼會排版,寫得知識也只是個人理解,如果問題請指出。希望大神們多多指教。

  

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 學前端需要掌握的第一個核心要點就是“玩命的學,玩命的練”,即韌性,不然很難學會,只有堅持下去才能學會。前端學習與前端教程有很多,如果你能“堅持”那麼就開始從簡單的前端模塊學習吧 前端要學習三個部分:HTML,CSS,JavaScript(簡稱JS),因此首先明確三個概念:HTML是內容層,它的目的是 ...
  • 網頁佈局基礎 簡介 什麼是網頁佈局? 網頁佈局是網頁製作的基礎,使用DIV+CSS佈局網頁是基礎中的基礎。三種基本佈局方式:流式佈局,浮動佈局,絕對定位佈局。 W3C標準包括結構化標準語言,表現標準語言,行為標準語言,倡導結構,樣式,行為分離。 CSS中,存在三種定位機制:標準文檔流,浮動,絕對定位 ...
  • 上回書說道,JS中變數、運算符、分支結構、迴圈和嵌套迴圈等內容。本回就由本K給大伙嘮嘮JS中的BOM、DOM和事件。 一、“花心大蘿蔔”——BOM 1、震驚,FFF團為何對BOM舉起了火把——BOM簡介 BOM(Browser Object Model) 是指瀏覽器對象模型,在JS中BOM是個不折不 ...
  • 一個精美的網頁需要的樣式很多,在父級上設置的字體顏色或者大小,在其子元素中不一定全部相同,這時候要更改其中某一項的樣式怎麼辦呢。 很多新手朋友就不明白,會迷惑為什麼我使用class單獨命名了,重新設置了還是沒有變化,會考慮是不是格式錯了,是不是命名有問題,但是有沒有考慮過權重值呢,新手朋友對於權重值 ...
  • opacity透明在網頁製作中使用會很多,為了增加好看的效果,透明的樣式肯定是必不可少的。 記得之前做一個網頁,其中一個塊給了個30的高,背景半透明的黑色,上面有一排導航,導航字體的顏色也就成了灰黑色,本來是想做成白色字體,怎麼改都不行,以為是字體的ul層在背景塊的下麵,想用z-index把字體的層 ...
  • 通過JS實現banner圖的滾動主要是定時器的應用 先新建好banner圖的幾張圖片,最後一張與第一張用同一個,保證滾動的不間斷 改好樣式,需註意所有圖片要在同行顯示,否則不能向左滾動 聲明一個函數,為定時器函數,函數內通過switch結構執行,case的值通過聲明一個全局變數每次執行函數的時候使其 ...
  • DOM對象模型 【DOM樹節點】 DOM節點分為三大類:元素節點,文本節點,屬性節點: 文本節點,屬性節點為元素節點的兩個子節點; 通過getElment系列方法,可以去到元素節點; 【查看節點】 1.getElementById:通過id獲取唯一的節點;多個同名ID只會取到第一個; 2.etEle ...
  • 之前的某次番嗇看到油管上有這麼一個進度條,當時覺得挺好玩,一直想著做一個試試,剛纔弄了一下寫了一個不算太好看的簡陋版本,哈哈。 (本博客刷新會頭部會出現,因為並沒有真正的參與到瀏覽器載入是否完整這個渲染過程中來,所以只是一個表象,並不是說這個顯示完了就瀏覽器也載入完了所以資源。) ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...