成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

gulp詳細(xì)基礎(chǔ)教程

vibiu / 1557人閱讀

摘要:核心概念流流,簡(jiǎn)單來(lái)說(shuō)就是建立在面向?qū)ο蠡A(chǔ)上的一種抽象的處理數(shù)據(jù)的工具。類(lèi)型,設(shè)置輸出路徑以某個(gè)路徑的某個(gè)組成部分為基礎(chǔ)向后拼接。

一、gulp簡(jiǎn)介 1.gulp是什么?

gulp是前端開(kāi)發(fā)過(guò)程中一種基于流的代碼構(gòu)建工具,是自動(dòng)化項(xiàng)目的構(gòu)建利器;它不僅能對(duì)網(wǎng)站資源進(jìn)行優(yōu)化,而且在開(kāi)發(fā)過(guò)程中很多重復(fù)的任務(wù)能夠使用正確的工具自動(dòng)完成;使用它,不僅可以很愉快的編寫(xiě)代碼,而且大大提高我們的工作效率。
gulp是基于Nodejs的自動(dòng)任務(wù)運(yùn)行器, 它能自動(dòng)化地完成 javascript、coffee、sass、less、html/image、css 等文件的測(cè)試、檢查、合并、壓縮、格式化、瀏覽器自動(dòng)刷新、部署文件生成,并監(jiān)聽(tīng)文件在改動(dòng)后重復(fù)指定的這些步驟。在實(shí)現(xiàn)上,她借鑒了Unix操作系統(tǒng)的管道(pipe)思想,前一級(jí)的輸出,直接變成后一級(jí)的輸入,使得在操作上非常簡(jiǎn)單。通過(guò)本文,我們將學(xué)習(xí)如何使用Gulp來(lái)改變開(kāi)發(fā)流程,從而使開(kāi)發(fā)更加快速高效。
gulp 和 grunt 非常類(lèi)似,但相比于 grunt 的頻繁 IO 操作,gulp 的流操作,能更快地更便捷地完成構(gòu)建工作。

2.核心概念:流

流,簡(jiǎn)單來(lái)說(shuō)就是建立在面向?qū)ο蠡A(chǔ)上的一種抽象的處理數(shù)據(jù)的工具。在流中,定義了一些處理數(shù)據(jù)的基本操作,如讀取數(shù)據(jù),寫(xiě)入數(shù)據(jù)等,程序員是對(duì)流進(jìn)行所有操作的,而不用關(guān)心流的另一頭數(shù)據(jù)的真正流向。流不但可以處理文件,還可以處理動(dòng)態(tài)內(nèi)存、網(wǎng)絡(luò)數(shù)據(jù)等多種數(shù)據(jù)形式。

而gulp正是通過(guò)流和代碼優(yōu)于配置的策略來(lái)盡量簡(jiǎn)化任務(wù)編寫(xiě)的工作。這看起來(lái)有點(diǎn)“像jQuery”的方法,把動(dòng)作串起來(lái)創(chuàng)建構(gòu)建任務(wù)。早在Unix的初期,流就已經(jīng)存在了。流在Node.js生態(tài)系統(tǒng)中也扮演了重要的角色,類(lèi)似于*nix將幾乎所有設(shè)備抽象為文件一樣,Node將幾乎所有IO操作都抽象成了stream的操作。因此用gulp編寫(xiě)任務(wù)也可看作是用Node.js編寫(xiě)任務(wù)。當(dāng)使用流時(shí),gulp去除了中間文件,只將最后的輸出寫(xiě)入磁盤(pán),整個(gè)過(guò)程因此變得更快。

3.特點(diǎn)

易于使用
通過(guò)代碼優(yōu)于配置的策略,gulp 讓簡(jiǎn)單的任務(wù)簡(jiǎn)單,復(fù)雜的任務(wù)可管理。

  構(gòu)建快速

   利用 Node.js 流的威力,你可以快速構(gòu)建項(xiàng)目并減少頻繁的 IO 操作。

  易于學(xué)習(xí)

   通過(guò)最少的 API,掌握 gulp 毫不費(fèi)力,構(gòu)建工作盡在掌握:如同一系列流管道。

  插件高質(zhì)

   gulp 嚴(yán)格的插件指南確保插件如你期望的那樣簡(jiǎn)潔高質(zhì)得工作。
  

4.安裝

首先確保你已經(jīng)正確安裝了nodejs環(huán)境。然后以全局方式安裝gulp:

npm install -g gulp

全局安裝gulp后,還需要在每個(gè)要使用gulp的項(xiàng)目中都多帶帶安裝一次。把目錄切換到你的項(xiàng)目文件夾中,然后在命令行中執(zhí)行:

npm install gulp

如果想在安裝的時(shí)候把gulp寫(xiě)進(jìn)項(xiàng)目package.json文件的依賴(lài)中,則可以加上--save-dev:

 npm install --save-dev gulp

這樣就完成了gulp的安裝,接下來(lái)就可以在項(xiàng)目中應(yīng)用gulp了。

5.gulp的使用

1、建立gulpfile.js文件
gulp也需要一個(gè)文件作為它的主文件,在gulp中這個(gè)文件叫做gulpfile.js。
新建一個(gè)文件名為gulpfile.js的文件,然后放到你的項(xiàng)目目錄中。之后要做的事情就是在gulpfile.js文件中定義我們的任務(wù)了。下面是一個(gè)最簡(jiǎn)單的gulpfile.js文件內(nèi)容示例,它定義了一個(gè)默認(rèn)的任務(wù)。

var gulp = require("gulp");
gulp.task("default",function(){
    console.log("hello world");
});

此時(shí)我們的目錄結(jié)構(gòu)是這樣子的:

2 運(yùn)行g(shù)ulp任務(wù)
要運(yùn)行g(shù)ulp任務(wù),只需切換到存放gulpfile.js文件的目錄(windows平臺(tái)請(qǐng)使用cmd或者Power Shell等工具),然后在命令行中執(zhí)行g(shù)ulp命令就行了,gulp后面可以加上要執(zhí)行的任務(wù)名,例如gulp task1,如果沒(méi)有指定任務(wù)名,則會(huì)執(zhí)行任務(wù)名為default的默認(rèn)任務(wù)。

二、 gulp api 1.工作方式

在介紹gulp API之前,我們首先來(lái)說(shuō)一下gulp.js工作方式。在gulp中,使用的是Nodejs中的stream(流),首先獲取到需要的stream,然后可以通過(guò)stream的pipe()方法把流導(dǎo)入到你想要的地方,比如gulp的插件中,經(jīng)過(guò)插件處理后的流又可以繼續(xù)導(dǎo)入到其他插件中,當(dāng)然也可以把流寫(xiě)入到文件中。所以gulp是以stream為媒介的,它不需要頻繁的生成臨時(shí)文件,這也是我們應(yīng)用gulp的一個(gè)原因。
  gulp的使用流程一般是:首先通過(guò)gulp.src()方法獲取到想要處理的文件流,然后把文件流通過(guò)pipe方法導(dǎo)入到gulp的插件中,最后把經(jīng)過(guò)插件處理后的流再通過(guò)pipe方法導(dǎo)入到gulp.dest()中,gulp.dest()方法則把流中的內(nèi)容寫(xiě)入到文件中。例如:

var gulp = require("gulp");
gulp.src("script/jquery.js")         // 獲取流的api
    .pipe(gulp.dest("dist/foo.js")); // 寫(xiě)放文件的api


2.src:獲取流

gulp.src()方法正是用來(lái)獲取流的,但要注意這個(gè)流里的內(nèi)容不是原始的文件流,而是一個(gè)虛擬文件對(duì)象流(Vinyl files),這個(gè)虛擬文件對(duì)象中存儲(chǔ)著原始文件的路徑、文件名、內(nèi)容等信息。其語(yǔ)法為:

gulp.src(globs[, options]);

globs參數(shù)是文件匹配模式(類(lèi)似正則表達(dá)式),用來(lái)匹配文件路徑(包括文件名),當(dāng)然這里也可以直接指定某個(gè)具體的文件路徑。當(dāng)有多個(gè)匹配模式時(shí),該參數(shù)可以為一個(gè)數(shù)組;類(lèi)型為String或 Array。當(dāng)有多種匹配模式時(shí)可以使用數(shù)組

//使用數(shù)組的方式來(lái)匹配多種文件

gulp.src(["js/*.js","css/*.css","*.html"])

options為可選參數(shù)。以下為options的選項(xiàng)參數(shù):
options.buffer

類(lèi)型: Boolean 默認(rèn)值: true
  如果該項(xiàng)被設(shè)置為 false,那么將會(huì)以 stream 方式返回 file.contents 而不是文件 buffer 的形式。這在處理一些大文件的時(shí)候?qū)?huì)很有用。

  注意:插件可能并不會(huì)實(shí)現(xiàn)對(duì) stream 的支持。

options.read
類(lèi)型: Boolean 默認(rèn)值: true
如果該項(xiàng)被設(shè)置為 false, 那么 file.contents 會(huì)返回空值(null),也就是并不會(huì)去讀取文件。
options.base
類(lèi)型: String , 設(shè)置輸出路徑以某個(gè)路徑的某個(gè)組成部分為基礎(chǔ)向后拼接。
如, 請(qǐng)想像一下在一個(gè)路徑為 client/js/somedir 的目錄中,有一個(gè)文件叫 somefile.js :

gulp.src("client/js/**/*.js") // 匹配 "client/js/somedir/somefile.js" 現(xiàn)在 `base` 的值為 `client/js/`
  .pipe(minify())
  .pipe(gulp.dest("build"));  // 寫(xiě)入 "build/somedir/somefile.js" 將`client/js/`替換為build
 
gulp.src("client/js/**/*.js", { base: "client" }) // base 的值為 "client"
  .pipe(minify())
  .pipe(gulp.dest("build"));  // 寫(xiě)入 "build/js/somedir/somefile.js" 將`client`替換為build
3.dest:寫(xiě)文件

gulp.dest()方法是用來(lái)寫(xiě)文件的,其語(yǔ)法為:

gulp.dest(path[,options])

path為寫(xiě)入文件的路徑;
options為一個(gè)可選的參數(shù)對(duì)象,以下為選項(xiàng)參數(shù):
options.cwd
類(lèi)型: String 默認(rèn)值: process.cwd()
輸出目錄的 cwd 參數(shù),只在所給的輸出目錄是相對(duì)路徑時(shí)候有效。
options.mode
類(lèi)型: String 默認(rèn)值: 0777
八進(jìn)制權(quán)限字符,用以定義所有在輸出目錄中所創(chuàng)建的目錄的權(quán)限。

var gulp = require("gulp");
gulp.src("script/jquery.js")        // 獲取流
    .pipe(gulp.dest("dist/foo.js")); // 寫(xiě)放文件

下面再說(shuō)說(shuō)生成的文件路徑與我們給gulp.dest()方法傳入的路徑參數(shù)之間的關(guān)系。
 gulp.dest(path)生成的文件路徑是我們傳入的path參數(shù)后面再加上gulp.src()中有通配符開(kāi)始出現(xiàn)的那部分路徑。例如:

var gulp = reruire("gulp");

//有通配符開(kāi)始出現(xiàn)的那部分路徑為 */.js

gulp.src("script/**/*.js")
    .pipe(gulp.dest("dist")); //最后生成的文件路徑為 dist/**/*.js//如果 **/*.js 匹配到的文件為 jquery/jquery.js ,則生成的文件路徑為 dist/jquery/jquery.js

用gulp.dest()把文件流寫(xiě)入文件后,文件流仍然可以繼續(xù)使用。

4.watch:監(jiān)聽(tīng)文件

gulp.watch()用來(lái)監(jiān)視文件的變化,當(dāng)文件發(fā)生變化后,我們可以利用它來(lái)執(zhí)行相應(yīng)的任務(wù),例如文件壓縮等。其語(yǔ)法為

gulp.watch(glob[, opts], tasks); 

glob 為要監(jiān)視的文件匹配模式,規(guī)則和用法與gulp.src()方法中的glob相同。 opts 為一個(gè)可選的配置對(duì)象,通常不需要用到。 tasks 為文件變化后要執(zhí)行的任務(wù),為一個(gè)數(shù)組。

gulp.task("uglify",function(){
  //do something
});
gulp.task("reload",function(){
  //do something
});
gulp.watch("js/**/*.js", ["uglify","reload"]);
       gulp.watch()還有另外一種使用方式:
gulp.watch(glob[, opts, cb]);

glob和opts參數(shù)與第一種用法相同;
cb參數(shù)為一個(gè)函數(shù)。每當(dāng)監(jiān)視的文件發(fā)生變化時(shí),就會(huì)調(diào)用這個(gè)函數(shù),并且會(huì)給它傳入一個(gè)對(duì)象,該對(duì)象包含了文件變化的一些信息,type屬性為變化的類(lèi)型,可以是added,changed,deleted;path屬性為發(fā)生變化的文件的路徑。

gulp.watch("js/**/*.js", function(event){
    console.log(event.type); //變化類(lèi)型 added為新增,deleted為刪除,changed為改變 
    console.log(event.path); //變化的文件的路徑
}); 
5.task:定義任務(wù)

gulp.task方法用來(lái)定義任務(wù),其語(yǔ)法為:

gulp.task(name[, deps], fn)

name 為任務(wù)名;
deps 是當(dāng)前定義的任務(wù)需要依賴(lài)的其他任務(wù),為一個(gè)數(shù)組。當(dāng)前定義的任務(wù)會(huì)在所有依賴(lài)的任務(wù)執(zhí)行完畢后才開(kāi)始執(zhí)行。如果沒(méi)有依賴(lài),則可省略這個(gè)參數(shù);
fn 為任務(wù)函數(shù),我們把任務(wù)要執(zhí)行的代碼都寫(xiě)在里面。該參數(shù)也是可選的。
當(dāng)你定義一個(gè)簡(jiǎn)單的任務(wù)時(shí),需要傳入任務(wù)名字和執(zhí)行函數(shù)兩個(gè)屬性。

gulp.task("greet", function () {
   console.log("Hello world!");
});

執(zhí)行g(shù)ulp greet的結(jié)果就是在控制臺(tái)上打印出“Hello world”。
你也可以定義一個(gè)在gulp開(kāi)始運(yùn)行時(shí)候默認(rèn)執(zhí)行的任務(wù),并將這個(gè)任務(wù)命名為“default”:

gulp.task("default", function () {
   // Your default task
});

前面已經(jīng)介紹了gulp.task的語(yǔ)法,但是當(dāng)有多個(gè)任務(wù)時(shí),需要知道怎么來(lái)控制任務(wù)的執(zhí)行順序。
可以通過(guò)任務(wù)依賴(lài)來(lái)實(shí)現(xiàn)。例如我想要執(zhí)行one,two,three這三個(gè)任務(wù),那我們就可以定義一個(gè)空的任務(wù),然后把那三個(gè)任務(wù)當(dāng)做這個(gè)空的任務(wù)的依賴(lài)就行了:
//只要執(zhí)行default任務(wù),就相當(dāng)于把one,two,three這三個(gè)任務(wù)執(zhí)行了

gulp.task("default",["one","two","three"]);
   如果任務(wù)相互之間沒(méi)有依賴(lài),任務(wù)就會(huì)按你書(shū)寫(xiě)的順序來(lái)執(zhí)行,如果有依賴(lài)的話(huà)則會(huì)先執(zhí)行依賴(lài)的任務(wù)。但是如果某個(gè)任務(wù)所依賴(lài)的任務(wù)是異步的,就要注意了,gulp并不會(huì)等待那個(gè)所依賴(lài)的異步任務(wù)完成,而是會(huì)接著執(zhí)行后續(xù)的任務(wù)。例如:
gulp.task("one",function(){
  //one是一個(gè)異步執(zhí)行的任務(wù)
  setTimeout(function(){
    console.log("one is done")
  },5000);
});
 
//two任務(wù)雖然依賴(lài)于one任務(wù),但并不會(huì)等到one任務(wù)中的異步操作完成后再執(zhí)行
gulp.task("two",["one"],function(){
  console.log("two is done");
});

上面的例子中我們執(zhí)行two任務(wù)時(shí),會(huì)先執(zhí)行one任務(wù),但不會(huì)去等待one任務(wù)中的異步操作完成后再執(zhí)行two任務(wù),而是緊接著執(zhí)行two任務(wù)。所以two任務(wù)會(huì)在one任務(wù)中的異步操作完成之前就執(zhí)行了。
  那如果我們想等待異步任務(wù)中的異步操作完成后再執(zhí)行后續(xù)的任務(wù),該怎么做呢?

有三種方法可以實(shí)現(xiàn):
 

第一:在異步操作完成后執(zhí)行一個(gè)回調(diào)函數(shù)來(lái)通知gulp這個(gè)異步任務(wù)已經(jīng)完成,這個(gè)回調(diào)函數(shù)就是任務(wù)函數(shù)的第一個(gè)參數(shù)。

gulp.task("one", function (cb) { //cb為任務(wù)函數(shù)提供的回調(diào),用來(lái)通知任務(wù)已經(jīng)完成
    //one是一個(gè)異步執(zhí)行的任務(wù)
    exec("", function (err) {
        setTimeout(function () {
            if (err) {
                return cb(err);
            }
            console.log("one is finish");
            cb();  //執(zhí)行回調(diào),表示這個(gè)異步任務(wù)已經(jīng)完成
        }, 5000)
    });
});

//這時(shí)two任務(wù)會(huì)在one任務(wù)中的異步操作完成后再執(zhí)行
gulp.task("two", ["one"], function () {
    console.log("two is finish");
});

第二:定義任務(wù)時(shí)返回一個(gè)流對(duì)象。適用于任務(wù)就是操作gulp.src獲取到的流的情況。

gulp.task("one",function(cb){
  var stream = gulp.src("client/**/*.js")
      .pipe(exec()) //exec()中有某些異步操作
      .pipe(gulp.dest("build"));
    return stream;
});
 
gulp.task("two",["one"],function(){
  console.log("two is done");
});

第三:返回一個(gè)promise對(duì)象,例如

var Q = require("q");
gulp.task("one", function() {
  var deferred = Q.defer();
 
  // 執(zhí)行異步的操作
  setTimeout(function() {
    deferred.resolve();
  }, 1);
  return deferred.promise;
});
 
gulp.task("two",["one"],function(){
  console.log("two is done");
});
三、寫(xiě)自己的gulp任務(wù) 1.項(xiàng)目需求

我們將創(chuàng)建一個(gè)自己的gulp,具體的需求是通過(guò)gulp把我們自己所編寫(xiě)的JS文件合并壓縮、CSS文件進(jìn)行壓縮后,并且生成新的文件。我們所需要的插件為:gulp-minify-css gulp-concat gulp-uglify gulp-rename 如下圖所示,完成后的項(xiàng)目目錄結(jié)構(gòu):

2.安裝插件

根據(jù)我們項(xiàng)目的需求,安裝所需要的插件,可以通過(guò)"npm install 插件名" 來(lái)安裝插件
然后打開(kāi)gulpfile.js,將我們所用到的插件引用到我們項(xiàng)目中,代碼如下:

var gulp = require("gulp"),
    minifycss = require("gulp-minify-css"),  //CSS壓縮
    concat = require("gulp-concat"),         // 文件合并
    uglify = require("gulp-uglify"),         //js壓縮插件
    rename = require("gulp-rename");         // 重命名
    
3.編寫(xiě)任務(wù)代碼

1.壓縮css

gulp.task("minifycss", function() {
    return gulp.src("src/css/*.css")         //壓縮的文件
        .pipe(minifycss())                   //執(zhí)行壓縮
        .pipe(gulp.dest("dist/css"));        //輸出文件夾
});

2.JS 合并壓縮

gulp.task("minifyjs", function() {
    return gulp.src("src/js/*.js")
        .pipe(concat("all.js"))               //合并所有js到main.js
        .pipe(gulp.dest("dist/js"))           //輸出main.js到文件夾
        .pipe(rename({suffix: ".min"}))       //rename壓縮后的文件名
        .pipe(uglify())                       //壓縮
        .pipe(gulp.dest("dist/js"));          //輸出
});

3.將以上兩個(gè)任務(wù)合并為一個(gè)任務(wù)

gulp.task("build", ["minifycss", "minifyjs"]);

4.監(jiān)視文件的變化,自動(dòng)執(zhí)行任務(wù)

// 監(jiān)視文件的變化,當(dāng)文件有更新時(shí)執(zhí)行build任務(wù)
gulp.task("watch", function () {
    gulp.watch(["src/js/*.js", "src/css/*.css"], ["build"]);
});

5.定義默認(rèn)任務(wù)

   
gulp.task("default", ["build", "watch"]);
4.執(zhí)行任務(wù)

在命令行中先轉(zhuǎn)到gulp-demo目錄下,就可以輸入gulp命令來(lái)運(yùn)行本項(xiàng)目了,刷新gulp-demo目錄看看會(huì)出現(xiàn)什么結(jié)果呢。運(yùn)行完成后的目錄如下圖:

運(yùn)行過(guò)程中的消息如下圖所示:

以下是常用功能的總結(jié)

插件安裝在我們編寫(xiě)gulp代碼時(shí)候,需要用到一些gulp的插件,可以通過(guò)npm install --save-dev 插件名稱(chēng) 來(lái)安裝。如下代碼來(lái)安裝自動(dòng)加載插件:
npm install --save-dev gulp-load-plugins
要使用gulp的插件,首先得用require來(lái)把插件加載進(jìn)來(lái)。

var gulp=require("gulp"),
    plugins=require("gulp-load-plugins")(),
    uglify = require("gulp-uglify"),
    minifyHtml = require("gulp-minify-html"),
    rename = require("gulp-rename");

gulp的插件有很多種,我們將在本節(jié)內(nèi)容中為同學(xué)們講解幾個(gè)插件的用法。如還想了解更多插件,請(qǐng)查閱相關(guān)資料。
自動(dòng)加載gulp-load-plugins這個(gè)插件能自動(dòng)幫你加載package.json文件里的gulp插件。例如假設(shè)你的package.json文件里的依賴(lài)是這樣的:

{
  "devDependencies": {
    "gulp": "~3.6.0",
    "gulp-rename": "~1.2.0",
    "gulp-ruby-sass": "~0.4.3",
    "gulp-load-plugins": "~0.5.1"
  }
}

然后我們可以在gulpfile.js中使用gulp-load-plugins來(lái)幫我們加載插件:

    var gulp = require("gulp");

//加載gulp-load-plugins插件,并馬上運(yùn)行它
var plugins = require("gulp-load-plugins")();

然后我們要使用gulp-rename和gulp-ruby-sass這兩個(gè)插件的時(shí)候,就可以使用plugins.rename和plugins.rubySass來(lái)代替了,也就是原始插件名去掉gulp-前綴,之后再轉(zhuǎn)換為駝峰命名。
重命名gulp-rename插件用來(lái)重命名文件流中的文件。用gulp.dest()方法寫(xiě)入文件時(shí),文件名使用的是文件流中的文件名,如果要想改變文件名,那可以在之前用gulp-rename插件來(lái)改變文件流中的文件名。

var gulp = require("gulp"),
    rename = require("gulp-rename"),
    uglify = require("gulp-uglify");
 
gulp.task("rename", function () {
    gulp.src("src/1.js")
    .pipe(uglify())           //壓縮
    .pipe(rename("1.min.js")) //會(huì)將1.js重命名為1.min.js
    .pipe(gulp.dest("js"));
});

js文件壓縮gulp-uglify插件用來(lái)壓縮js文件。

var gulp = require("gulp"),
    uglify = require("gulp-uglify");
 
gulp.task("minify-js", function () {
    gulp.src("src/*.js")          // 要壓縮的js文件
    .pipe(uglify())              //使用uglify進(jìn)行壓縮
    .pipe(gulp.dest("dist/js")); //壓縮后的路徑
});

css文件壓縮gulp-minify-css插件用來(lái)壓縮css文件。

var gulp = require("gulp"),
    minifyCss = require("gulp-minify-css");
 
gulp.task("minify-css", function () {
    gulp.src("src/*.css") // 要壓縮的css文件
    .pipe(minifyCss())    //壓縮css
    .pipe(gulp.dest("dist/css"));
});

html文件壓縮gulp-minify-html插件用來(lái)壓縮html文件。

var gulp = require("gulp"),
    minifyHtml = require("gulp-minify-html");
 
gulp.task("minify-html", function () {
    gulp.src("src/*.html") // 要壓縮的html文件
    .pipe(minifyHtml())    //壓縮
    .pipe(gulp.dest("dist/html"));
});

js代碼檢查使用gulp-jshint插件,用來(lái)檢查js代碼。

var gulp = require("gulp"),
    jshint = require("gulp-jshint");
 
gulp.task("jsLint", function () {
    gulp.src("src/*.js")
    .pipe(jshint())
    .pipe(jshint.reporter()); // 輸出檢查結(jié)果
});

文件合并使用gulp-concat插件,用來(lái)把多個(gè)文件合并為一個(gè)文件,我們可以用它來(lái)合并js或css文件等。

var gulp = require("gulp"),
    concat = require("gulp-concat");
gulp.task("concat", function () {
    gulp.src("src/*.js")     //要合并的文件
    .pipe(concat("all.js"))  // 合并匹配到的js文件并命名為 "all.js"
    .pipe(gulp.dest("dist/js"));
});

圖片壓縮可以使用gulp-imagemin插件來(lái)壓縮jpg、png、gif等圖片。

var gulp = require("gulp");
var imagemin = require("gulp-imagemin");
var pngquant = require("imagemin-pngquant"); //png圖片壓縮插件
gulp.task("default", function () {
    return gulp.src("src/images/*")
        .pipe(imagemin({
            progressive: true,
            use: [pngquant()] //使用pngquant來(lái)壓縮png圖片
        }))
        .pipe(gulp.dest("dist"));
});

自動(dòng)刷新使用gulp-livereload插件,當(dāng)代碼變化時(shí),它可以幫我們自動(dòng)刷新頁(yè)面。

var gulp = require("gulp"),
    less = require("gulp-less"),
    livereload = require("gulp-livereload");
gulp.task("less", function() {
  gulp.src("less/*.less")
    .pipe(less())
    .pipe(gulp.dest("css"))
    .pipe(livereload());
});
gulp.task("watch", function() {
  livereload.listen(); //要在這里調(diào)用listen()方法
  gulp.watch("less/*.less", ["less"]);
});

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

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/85930.html

相關(guān)文章

  • gulp詳細(xì)基礎(chǔ)教程

    摘要:核心概念流流,簡(jiǎn)單來(lái)說(shuō)就是建立在面向?qū)ο蠡A(chǔ)上的一種抽象的處理數(shù)據(jù)的工具。類(lèi)型,設(shè)置輸出路徑以某個(gè)路徑的某個(gè)組成部分為基礎(chǔ)向后拼接。 一、gulp簡(jiǎn)介 1.gulp是什么? gulp是前端開(kāi)發(fā)過(guò)程中一種基于流的代碼構(gòu)建工具,是自動(dòng)化項(xiàng)目的構(gòu)建利器;它不僅能對(duì)網(wǎng)站資源進(jìn)行優(yōu)化,而且在開(kāi)發(fā)過(guò)程中很多重復(fù)的任務(wù)能夠使用正確的工具自動(dòng)完成;使用它,不僅可以很愉快的編寫(xiě)代碼,而且大大提高我們的工...

    xuhong 評(píng)論0 收藏0
  • gulp詳細(xì)基礎(chǔ)教程

    摘要:核心概念流流,簡(jiǎn)單來(lái)說(shuō)就是建立在面向?qū)ο蠡A(chǔ)上的一種抽象的處理數(shù)據(jù)的工具。類(lèi)型,設(shè)置輸出路徑以某個(gè)路徑的某個(gè)組成部分為基礎(chǔ)向后拼接。 一、gulp簡(jiǎn)介 1.gulp是什么? gulp是前端開(kāi)發(fā)過(guò)程中一種基于流的代碼構(gòu)建工具,是自動(dòng)化項(xiàng)目的構(gòu)建利器;它不僅能對(duì)網(wǎng)站資源進(jìn)行優(yōu)化,而且在開(kāi)發(fā)過(guò)程中很多重復(fù)的任務(wù)能夠使用正確的工具自動(dòng)完成;使用它,不僅可以很愉快的編寫(xiě)代碼,而且大大提高我們的工...

    張金寶 評(píng)論0 收藏0
  • 零React基礎(chǔ)入門(mén)Amaze UI Touch!

    摘要:全文的目的是達(dá)成使用進(jìn)行項(xiàng)目開(kāi)發(fā),并且以我這個(gè)前端菜鳥(niǎo)所見(jiàn)所學(xué)來(lái)歸納整理。環(huán)境安裝與前期準(zhǔn)備我的基礎(chǔ)環(huán)境出的開(kāi)源的編輯器命令行工具,下一個(gè)炒雞好用的神器。只提供組件,對(duì)配套技術(shù)不做限定,方便用戶(hù)與現(xiàn)有技術(shù)??焖僬?,降低使用成本。 全文的目的是達(dá)成使用amazeui-touch進(jìn)行項(xiàng)目開(kāi)發(fā),并且以我這個(gè)前端菜鳥(niǎo)所見(jiàn)所學(xué)來(lái)歸納整理。文章不對(duì)詳細(xì)內(nèi)容做講解。 環(huán)境安裝與前期準(zhǔn)備 我的基礎(chǔ)環(huán)...

    王晗 評(píng)論0 收藏0
  • 零React基礎(chǔ)入門(mén)Amaze UI Touch!

    摘要:全文的目的是達(dá)成使用進(jìn)行項(xiàng)目開(kāi)發(fā),并且以我這個(gè)前端菜鳥(niǎo)所見(jiàn)所學(xué)來(lái)歸納整理。環(huán)境安裝與前期準(zhǔn)備我的基礎(chǔ)環(huán)境出的開(kāi)源的編輯器命令行工具,下一個(gè)炒雞好用的神器。只提供組件,對(duì)配套技術(shù)不做限定,方便用戶(hù)與現(xiàn)有技術(shù)??焖僬?,降低使用成本。 全文的目的是達(dá)成使用amazeui-touch進(jìn)行項(xiàng)目開(kāi)發(fā),并且以我這個(gè)前端菜鳥(niǎo)所見(jiàn)所學(xué)來(lái)歸納整理。文章不對(duì)詳細(xì)內(nèi)容做講解。 環(huán)境安裝與前期準(zhǔn)備 我的基礎(chǔ)環(huán)...

    OldPanda 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<