欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Grunt針對(duì)靜態(tài)文件的壓縮,版本控制打包的實(shí)例講解

 更新時(shí)間:2017年09月29日 08:00:42   作者:Bard·J  
下面小編就為大家?guī)?lái)一篇Grunt針對(duì)靜態(tài)文件的壓縮,版本控制打包的實(shí)例講解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

在講之前先談?wù)劥笾虏襟E:安裝nodejs -> 全局安裝grunt -> 項(xiàng)目創(chuàng)建package.json --> 項(xiàng)目安裝grunt以及grunt插件 -> 配置Gruntfile.js -> 運(yùn)行任務(wù)

1.安裝Node

我們開(kāi)始之前需要安裝Nodejs,如果沒(méi)有安裝的 傳送門

安裝好了之后,查看是否安裝成功,正常是這樣的提示

這里建議npm換成淘寶的cnpm,速度杠杠的。

安裝命令:

npm install cnpm -g -registry=https://registry.npm.taobao.org

2.安裝全局Grunt

安裝命令:

cnpm install grunt -g

3.項(xiàng)目創(chuàng)建package.json

在項(xiàng)目根目錄下創(chuàng)建package.json文件,文件內(nèi)容如下

4.項(xiàng)目安裝grunt以及grunt插件

我們所需要的插件

插件名稱 說(shuō)明 Github地址
grunt-contrib-clean 清空文件和文件夾 https://github.com/gruntjs/grunt-contrib-clean
grunt-contrib-copy 復(fù)制文件和文件夾 https://github.com/gruntjs/grunt-contrib-copy
grunt-contrib-concat 連接、合并文件(沒(méi)用到 https://github.com/gruntjs/grunt-contrib-concat
grunt-contrib-cssmin (CSS文件)壓縮 https://github.com/gruntjs/grunt-contrib-cssmin
grunt-contrib-uglify (JS文件)壓縮 https://github.com/gruntjs/grunt-contrib-uglify
grunt-filerev 文件內(nèi)容hash(MD5)(版本號(hào)控制) https://github.com/yeoman/grunt-filerev
grunt-usemin 文件進(jìn)行引用修改 https://github.com/yeoman/grunt-usemin
load-grunt-tasks oad-grunt-tasks https://github.com/sindresorhus/load-grunt-tasks

我們打開(kāi)我們的項(xiàng)目文件夾,在路徑欄中輸入cmd然后回車

回車后的界面

打開(kāi)命令行窗口之后,我們輸入安裝命令:

cnpm install grunt grunt-contrib-clean grunt-contrib-copy grunt-contrib-concat grunt-contrib-cssmin grunt-contrib-uglify grunt-filerev grunt-usemin load-grunt-tasks --save-dev

5.配置Gruntfile.js (這是重點(diǎn),重點(diǎn),重點(diǎn)。重要的事情說(shuō)三遍。)

先貼一下我的配置,后面慢慢說(shuō)明

module.exports = function (grunt) {
 require('load-grunt-tasks')(grunt);

 var path = {
  src : 'test',
  dest : 'dist',
 }

 grunt.initConfig({
  path : path,
  clean : {//清空生產(chǎn)文件夾
   beforebuild : {
    files : [{
      src : ['<%= path.dest %>/']
     }
    ]
   }
  },
  filerev : {//對(duì)css和js文件重命名
   build : {
    files : [{
      src : ['<%= path.dest %>/**', 
      '!<%= path.dest %>/page/*.html',//html文件不加版本號(hào)
      '!<%= path.dest %>/**/*.{png,jpg,jpeg}']//圖片 不需要加版本號(hào)
     }
    ]
   }
  },
  useminPrepare : {//聲明concat、cssmin、uglify
   build : {
    files : [{     
      src : '<%= path.src %>/page/*.html'
     }
    ],
    
   }
  },
  usemin : {//修改html中的css和js引用
   html : {
    files : [{
      src : '<%= path.dest %>/page/*.html'
     }
    ]
   }
  },
  copy : {//復(fù)制文件
   build : {
    files : [{
      expand : true,//為true啟用cwd,src,dest選項(xiàng)
      cwd : '<%= path.src %>/',//所有src指定的匹配都將相對(duì)于此處指定的路徑(但不包括此路徑)
      src : ['**/*.*'],//相對(duì)于cwd路徑的匹配模式。意思就是 src/**/*.*,匹配src下面所有文件
      dest : '<%= path.dest %>/'//目標(biāo)文件路徑前綴。
     }
    ]
   }
  },
  cssmin :{
   build : {
    files : [{
      expand : true,//為true啟用cwd,src,dest選項(xiàng)
      cwd : '<%= path.src %>/',//所有src指定的匹配都將相對(duì)于此處指定的路徑(但不包括此路徑)
      src : ['css/*.css'],//相對(duì)于cwd路徑的匹配模式。意思就是 src/**/*.css,匹配src下面所有css文件
      dest : '<%= path.dest %>/'//目標(biāo)文件路徑前綴。
     }
    ]
   }
  },
  uglify :{
   build : {
    files : [{
      expand : true,//為true啟用cwd,src,dest選項(xiàng)
      cwd : '<%= path.src %>/',//所有src指定的匹配都將相對(duì)于此處指定的路徑(但不包括此路徑)
      src : ['js/*.js'],//相對(duì)于cwd路徑的匹配模式。意思就是 src/**/*.js,匹配src下面所有js文件
      dest : '<%= path.dest %>/'//目標(biāo)文件路徑前綴。
     }
    ]
   }
  },
 });
 grunt.registerTask('default', ['clean:beforebuild', 'copy', 'cssmin', 'uglify','filerev', 'usemin']);
};

我們前面一直都在安裝這個(gè)安裝那個(gè),但是安裝的這些東西怎么用起來(lái)了?

首先我們通過(guò)學(xué)習(xí) grunt入門 了解到插件如何使用,這是官網(wǎng)的例子。

pkg是通過(guò)讀取package.json生成的json對(duì)象。

uglify是 grunt-contrib-uglify 指定的任務(wù)名,每個(gè)插件都有對(duì)應(yīng)的任務(wù)名,可以在對(duì)應(yīng)的github里面查看

grunt.loadNpmTasks('grunt-contrib-uglify'); 從字面上就可以看出來(lái)/,加載能夠提供"uglify"任務(wù)的插件。

grunt.registerTask('default', ['uglify']); 注冊(cè)別名任務(wù),這個(gè)別名任務(wù)對(duì)應(yīng)的是一個(gè)任務(wù)列表

當(dāng)通過(guò) grunt 別名時(shí),實(shí)際是執(zhí)行列表里的任務(wù),并按順序執(zhí)行

這些基本的信息都可以通過(guò)官網(wǎng)查看。

我們來(lái)說(shuō)說(shuō)我們需求,我們需要對(duì)靜態(tài)文件打包壓縮,并且需要對(duì)靜態(tài)文件加入版本號(hào)而且所有引用靜態(tài)文件的html或css都得修改文件名,我們的需求明確后來(lái)來(lái)看看我們?cè)趺醋觥?/p>

第一步:我們需要重新打包,那就需要復(fù)制文件,所以我們需要grunt-contrib-copy插件。

在copy之前我們先要確定源文件和目標(biāo)文件,我這里源文件都放在test文件夾中,目標(biāo)文件都放在dist文件夾中

我們創(chuàng)建文件路徑

var path = {
  src : 'test',
  dest : 'dist',
 }

文件路徑創(chuàng)建好了,我們來(lái)看copy

copy : {//復(fù)制文件
   build : {
    files : [{
      expand : true,//為true啟用cwd,src,dest選項(xiàng)
      cwd : '<%= path.src %>/',//所有src指定的匹配都將相對(duì)于此處指定的路徑(但不包括此路徑)
      src : ['**/*.*'],//相對(duì)于cwd路徑的匹配模式。意思就是 src/**/*.*,匹配src下面所有文件
      dest : '<%= path.dest %>/'//目標(biāo)文件路徑前綴。
     }
    ]
   }
  },

從代碼的注釋就可以看出一二了。這里說(shuō)下cwd,src,dest 。

其實(shí)這里的源路徑是 cwd + src。這才是真正的源路徑。dest是目標(biāo)路徑前綴。

我這里的意思是src下面所有的文件,意思就是把 src文件夾 里面的文件復(fù)制到 dest文件夾 里。這里可以指定需要復(fù)制的具體文件夾或者文件類型

第二步:進(jìn)行文件壓縮,我這里只是針對(duì)js和css壓縮,對(duì)img的壓縮可以查看對(duì)應(yīng)的插件,思路都一樣。

css壓縮需要用到 grunt-contrib-cssmin 插件,該插件對(duì)應(yīng)的任務(wù)名為 cssmin

cssmin :{
   build : {
    files : [{
      expand : true,//為true啟用cwd,src,dest選項(xiàng)
      cwd : '<%= path.src %>/',//所有src指定的匹配都將相對(duì)于此處指定的路徑(但不包括此路徑)
      src : ['css/*.css'],//相對(duì)于cwd路徑的匹配模式。意思就是 src/**/*.css,匹配src下面所有文件
      dest : '<%= path.dest %>/'//目標(biāo)文件路徑前綴。
     }
    ]
   }
  },

js 壓縮需要用到 grunt-contrib-uglify 插件,該插件對(duì)應(yīng)的任務(wù)名為 uglify

uglify :{
   build : {
    files : [{
      expand : true,//為true啟用cwd,src,dest選項(xiàng)
      cwd : '<%= path.src %>/',//所有src指定的匹配都將相對(duì)于此處指定的路徑(但不包括此路徑)
      src : ['js/*.js'],//相對(duì)于cwd路徑的匹配模式。意思就是 src/**/*.js,匹配src下面所有文件
      dest : '<%= path.dest %>/'//目標(biāo)文件路徑前綴。
     }
    ]
   }
  },

第三步:靜態(tài)文件重命名,我們這里的版本控制是通過(guò)對(duì)靜態(tài)文件重命名來(lái)現(xiàn)實(shí)的。

重命名需要用到 grunt-filerev 插件,該插件對(duì)應(yīng)的任務(wù)名為 filerev

filerev : {//對(duì)css和js文件重命名
   build : {
    files : [{
      src : ['<%= path.dest %>/**', 
      '!<%= path.dest %>/page/*.html',//html文件不加版本號(hào)
      '!<%= path.dest %>/**/*.{png,jpg,jpeg}']//圖片 不需要加版本號(hào)
     }
    ]
   }
  },

這里只有一個(gè)src參數(shù),傳的是個(gè)數(shù)組,我們這里是只想給css和js重命名,其他文件不需要。所以數(shù)組第一個(gè)參數(shù) src/** 匹配src文件夾中所有文件,后面兩個(gè) ! xx,是排除的意思,

第四步:修改html中css和js的引用

修改文件引用需要用到 grunt-usemin 插件,該插件對(duì)應(yīng)的任務(wù)名為 usemin

usemin : {//修改html中的css和js引用
   html : {
    files : [{
      src : '<%= path.dest %>/page/*.html'
     }
    ]
   }
  },

這里也只有一個(gè)src參數(shù),給出的是html的地址,如果你還有css 可以這樣寫

usemin : {//修改html中的css和js引用
   html : {
    files : [{
      src : '<%= path.dest %>/page/*.html'
     }
    ]
   },
   css :{
    files : [{
      src : '<%= path.dest %>/css/*.css'
     }
    ]
   }
  },

第五步:我們從 復(fù)制,壓縮,重命名,修改引用都說(shuō)了一遍,這里還少一個(gè)東西,就是我們每次復(fù)制之前需要把目標(biāo)文件夾里面的文件刪除掉。

修改文件引用需要用到 grunt-contrib-clean 插件,該插件對(duì)應(yīng)的任務(wù)名為 clean

clean : {//清空生產(chǎn)文件夾
   beforebuild : {
    files : [{
      src : ['<%= path.dest %>/']
     }
    ]
   }
  },

這里也只有一個(gè)src參數(shù),給出目標(biāo)文件夾的地址。

所有任務(wù)到這里就結(jié)算了。

我們注冊(cè)任務(wù)別

grunt.registerTask('default', ['clean:beforebuild', 'copy', 'cssmin', 'uglify','filerev', 'usemin']);

可以看到,我們這里只是注冊(cè)了任務(wù),并沒(méi)有應(yīng)用插件。我們添加插件是聽(tīng)過(guò) load-grunt-tasks 插件完成的

require('load-grunt-tasks')(grunt);

這里指令相當(dāng)于我們一個(gè)個(gè)寫

grunt.loadNpmTasks('xxx');

Gruntfile.js 配置完了之后我們執(zhí)行g(shù)runt命令就可以在目標(biāo)文件夾中得到我們所需要的文件

這里補(bǔ)充說(shuō)明幾點(diǎn):

Gruntfile.js 配置完了之后我們執(zhí)行g(shù)runt命令就可以在目標(biāo)文件夾中得到我們所需要的文件

這里補(bǔ)充說(shuō)明幾點(diǎn)

這種寫法是動(dòng)態(tài)構(gòu)建文件對(duì)象

這種寫法是文件數(shù)組格式 

以上這篇Grunt針對(duì)靜態(tài)文件的壓縮,版本控制打包的實(shí)例講解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 詳解Node.js模板引擎Jade入門

    詳解Node.js模板引擎Jade入門

    這篇文章主要介紹了詳解Node.js模板引擎Jade入門,Jade是Node.js的一個(gè)模板引擎,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-01-01
  • nodejs實(shí)現(xiàn)jwt的示例代碼

    nodejs實(shí)現(xiàn)jwt的示例代碼

    本文主要介紹了nodejs實(shí)現(xiàn)jwt的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • node中Express 動(dòng)態(tài)設(shè)置端口的方法

    node中Express 動(dòng)態(tài)設(shè)置端口的方法

    本篇文章主要介紹了node中Express 動(dòng)態(tài)設(shè)置端口的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08
  • 使用Jasmine和Karma對(duì)AngularJS頁(yè)面程序進(jìn)行測(cè)試

    使用Jasmine和Karma對(duì)AngularJS頁(yè)面程序進(jìn)行測(cè)試

    這篇文章主要介紹了使用Jasmine和Karma對(duì)AngularJS頁(yè)面程序進(jìn)行測(cè)試的方法,以Node.js為環(huán)境,非常適合JavaScript的全棧開(kāi)發(fā)時(shí)使用,需要的朋友可以參考下
    2016-03-03
  • node.js中實(shí)現(xiàn)同步操作的3種實(shí)現(xiàn)方法

    node.js中實(shí)現(xiàn)同步操作的3種實(shí)現(xiàn)方法

    這篇文章主要介紹了node.js中實(shí)現(xiàn)同步操作的3種實(shí)現(xiàn)方法,本文用實(shí)例講解一些需要同步操作的情況下,如何編程實(shí)現(xiàn),需要的朋友可以參考下
    2014-12-12
  • node版本下報(bào)錯(cuò)build: `vue-cli-service build`問(wèn)題及解決

    node版本下報(bào)錯(cuò)build: `vue-cli-service build`問(wèn)題及解決

    這篇文章主要介紹了node版本下報(bào)錯(cuò)build: `vue-cli-service build`問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • 純異步nodejs文件夾(目錄)復(fù)制功能

    純異步nodejs文件夾(目錄)復(fù)制功能

    這篇文章主要介紹了純異步nodejs文件夾(目錄)復(fù)制功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09
  • NodeJS?Express使用ORM模型訪問(wèn)關(guān)系型數(shù)據(jù)庫(kù)流程詳解

    NodeJS?Express使用ORM模型訪問(wèn)關(guān)系型數(shù)據(jù)庫(kù)流程詳解

    這篇文章主要介紹了NodeJS?Express使用ORM模型訪問(wèn)關(guān)系型數(shù)據(jù)庫(kù)流程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧
    2023-01-01
  • 初探nodeJS

    初探nodeJS

    本文主要介紹了nodeJS的基礎(chǔ)知識(shí)。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-01-01
  • Node.js連接postgreSQL并進(jìn)行數(shù)據(jù)操作

    Node.js連接postgreSQL并進(jìn)行數(shù)據(jù)操作

    自從MySQL被Oracle收購(gòu)以后,PostgreSQL逐漸成為開(kāi)源關(guān)系型數(shù)據(jù)庫(kù)的首選。這篇文章就給大家介紹了關(guān)于Node.js如何連接postgreSQL數(shù)據(jù)庫(kù),并進(jìn)行數(shù)據(jù)操作的方法,有需要的朋友們可以參考借鑒,下面來(lái)一起看看吧。
    2016-12-12

最新評(píng)論