《移動Web前端高效開發實戰》筆記2——使用Gulp構建一個ECMAScript 6和Sass應用

来源:http://www.cnblogs.com/book2006/archive/2017/09/27/7604562.html
-Advertisement-
Play Games

使用Grunt構建項目涉及磁碟操作,構建效率較低,因此,基於流的Gulp應運而生。本節通過一個例子,介紹如何利用Gulp構建一個ECMAScript 6和Sass應用。 ...


8.3.1 安裝和配置

運行Gulp需要Node.js環境,請參看第二章內容搭建Node.js環境。使用NPM全局安裝Gulp,命令如下:

npm install gulp-cli –g

然後,在項目根目錄下創建package.json文件,命令如下:

npm init

根據引導配置項目信息。然後安裝Gulp依賴包,命令如下:

npm install gulp –save-dev

在項目根目錄下,創建gulpfile.js文件,內容如下:

var gulp = require("gulp");

gulp.task("default", function(){                     // 定義名稱為“default”的任務

         console.log("thisis default task");       // 此處定義default任務處理過程。

});

和Grunt相似,Gulp將構建過程拆解為一個個獨立的子任務,使用gulp.task方法定義任務。通過命令提示符進入到項目目錄,用“gulp 任務名”執行任務,實例命令如下:

gulp default

提示:對於預設(default)任務,可以省去任務名。

在創建任務的時候,和Grunt相似,可以指定任務的依賴項,代碼如下:

gulp.task(“main”, [“deps1”, “deps2”, …],function(){

         // 相關執行

});

gulp.task方法的第二個參數(數組)為“main”任務的依賴項。

項目中通常根據需求將構建過程拆解為多個小任務。下麵介紹如何具體定義。

首先,指定需要構建的內容,並通過Gulp插件來完成構建,最終輸出到指定的目錄。

採用gulp.src方法指定文件源,代碼如下:

gulp.src(“src/**/*.js”);:

// 或者 對於多個目錄下的源,可以採用數組

gulp.src([“src/**/*.js”, “theme/**/*.scss”]);

gulp.src方法返回Stream對象,可以通過pipe方法將內容傳遞給插件。所有插件都接受pipe傳遞過來的數據,處理數據允許鏈式調用,代碼如下:

gulp.src(“src/**/*.js”).pipe(plugin1()).pipe(plugin2())…

構建完畢後,需要採用gulp.dest方法將數據保存到文件中,代碼如下:

gulp.src(“src/**/*.js”).pipe(gulp.dest(“dist”));       // 讀取src下的所有js,寫入到dist目錄下

Gulp的每次操作都返迴流對象,所有操作在記憶體中進行,不需要操作磁碟,從而大幅提高了構建速度。

8.3.2 預處理任務

上一節中,介紹了Gulp的安裝,配置,以及Grunt任務的定義和執行。本節將介紹編譯ECMAScript 6、Sass和CSS Sprite任務。

“gulp-babel”插件可以將ECMAScript 6編譯為ECMAScript 5。以便運行在不支持ECMAScript 6的瀏覽器上。首先安裝該插件,命令如下:

npm install gulp-babel –save-dev

npm install babel-preset-es2015  --save-dev

然後,在gulpfile.js文件中創建任務,代碼如下:

var babel = require("gulp-babel");      // 引入babel

gulp.task("compile-js", function(){

         gulp.src("src/**/*.js")                    // 處理src下的所有js腳本

                   .pipe(babel({                       // 調用babel

                            presets:['es2015']     // 採用es2015預設插件,將腳本編譯為ECMAScript 5

                   }))

                   pipe(gulp.dest("dist/js"));   // 編譯好的內容保存到dist目錄下的js目錄

});

Babel可以將JavaScript文件,甚至React的JSX文件編譯為標準的JavaScript文件。Babel官方提供的預設插件(presets)讓用戶能夠更簡單地使用Babel。presets是針對特定編譯條件預設的一組插件集合。如本實例中,採用的es2015預設插件包含插件有“check-es2015-constants”,“transform-es2015-arrow-functions”等。

註意:Babel只是做了語法層次的轉換,並不會增加API的支持。對於class關鍵字定義的類,Babel會將其轉化為通過prototype定義的對象。而對於ECMAScript 6的Promise對象,Babel不會做任何處理,因此需要通過polyfill來對瀏覽器不支持的API進行擴展。如“es6-promise”使得瀏覽器支持Promise對象。

在實際的項目中,可以在根目錄下創建的“.babelrc”文件中配置Babel,代碼如下:

{

         "presets":["es2015"]

}

編譯Sass文件可以採用gulp-sass插件,安裝命令如下:

npm install gulp-sass –save-dev

然後,在gulpfile.js文件中,增加任務執行Sass編譯,代碼如下:

var sass = require("gulp-sass");                            // 引入sass插件

gulp.task("compile-sass", function(){                   // 定義編譯sass的任務

         gulp.src("theme/**/*.scss")                            // 處理theme下的所有的sass文件

         .pipe(sass().on('error',sass.logError))        // 採用sass插件編譯,並處理錯誤

         .pipe(gulp.dest("dist/css"));                           // 編譯好的內容輸出到dist目錄下的css目錄

});

在項目中,為了優化載入性能,需要將小圖片合成一張大圖,也就是所謂的“CSS Sprites”。該功能使用gulp.spritesmith插件來實現,安裝命令如下:

npm install gulp.spritesmith –save-dev

然後在gulpfile.js文件中建立任務,代碼如下:

var spritesmith = require('gulp.spritesmith');                // 引入sprite插件

gulp.task("sprite", function () {                                         // 定義任務

         gulp.src("theme/images/**.png")                          // 處理theme目錄下的png文件

                   .pipe(spritesmith({                                          // 調用插件合併圖片

                            imgName:'sprite.png',                         // 輸出合成的圖片名稱

                            cssName:'sprite.css'                            //輸出對應的css文件

                   }))

                   .pipe(gulp.dest("dist"));                                  // 輸出到dist目錄

});

 

本節介紹了三個預處理工具,有gulp-babel,gulp-sass和gulp.spritesmith。

 

更多信息關註:

 


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

-Advertisement-
Play Games
更多相關文章
  • 第一次在Vue中應用,swiper在在Vue之前引用會無效,需要在實例化Vue對象後再實例化Swiper才能產生效果 ...
  • 前一陣七夕前夕搞了一個微信活動,共用男女友,時間緊任務重,記得當時是周三提的需求,那就抓緊搞起來,後來會有一個生成圖片的功能,遇到了一些坎,下麵分析下技術點,用到的就是canvas的toDataURL()方法,可是生成圖片的時候,需要取微信授權後的用戶頭像和昵稱,調試了一番頭像的圖片總是概率性的不顯 ...
  • 分享自己封裝的前端分頁js工具類 下麵是預設樣式效果截圖 可以隨意更改js及css 很靈活 說明: ...
  • // var openid = $state.params.openid; var paramsArr = location.href.match(/\?\S+/)[0].replace('?', '').split('&'); vm.params = {}; for (var i = 0; i < ...
  • 學習 JavaScript 樹 ======================== 樹(Tree) 在電腦科學中,數據結構是一門研究 非數值計算 的程式設計問題中電腦的操作對象(數據元素)以及它們之間的操作和運算等的學科。 它包含三方面的內容: 數據的邏輯結構(常見有樹、圖、集合、線性) 數據存儲 ...
  • 本文主要從以下幾方面介紹jQuery應用中的內容: 1 jQuery 節點遍歷2 jQuery 中的過濾器3 jQuery 屬性操作4 jQuery Dom節點操作5 幾個jQuery例子6 jQuery 中的事件7 jQuery 中的動態效果 一、 jQuery 節點遍歷 == next() // ...
  • 一、練習一 1、需求效果分析: 2、代碼示例: 1 <!DOCTYPE html> 2 <html xmlns="http://www.w3.org/1999/xhtml"> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; ...
  • 寫幾個簡單的載入中動畫吧。 像前面三種都是相當於幾個不同的點輪流來播放同一動畫:變大變小。css3裡面有一個用於尺度變換的方法:scale(x,y):定義 2D 縮放轉換,改變元素的寬度和高度。 第四種就是一個小球從上往下跌落,再彈回去,在上面的時候速度最小,下麵的時候速度最大。由於該小球只進行了上 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...