摘要:以及列出的是本妹子最常用的插件,小伙伴們可以參考。案例地址二解決瀏覽器緩存問題為靜態(tài)文件添加唯一值,如。我們主要是用將轉(zhuǎn)換成可以在瀏覽器中運行的代碼。合并文件相關(guān)預(yù)處理器。
一、前言
有些簡單前端小項目,不需要涉及框架,前端打包壓縮的話本妹子還是喜歡用gulp。
本文將用gulp-rev和gulp-rev-rewrite解決cdn緩存問題。
以及列出的是本妹子最常用的gulp插件,小伙伴們可以參考。
案例地址:https://github.com/raoenhui/g...
1.為靜態(tài)文件添加唯一hash值,如 unicorn.css → unicorn-d41d8cd98f.css。
2.生成map映射文件,方便后面html更換文件名
gulp.task("js", () => gulp.src(["./src/app.js", "./src/app2.js"]) .pipe(gulp.dest("dist")) // 將源文件拷貝到打包目錄 .pipe(rev()) .pipe(gulp.dest("dist")) // 將生成的hash文件添加到打包目錄 .pipe(rev.manifest("js-rev.json")) .pipe(gulp.dest("dist")) // 將map映射文件添加到打包目錄 ); gulp.task("css",()=> { gulp.src("./src/*.css") .pipe(gulp.dest("dist")) // 將生成的hash文件添加到打包目錄 .pipe(rev()) .pipe(gulp.dest("dist"))// write rev"d assets to build dir .pipe(rev.manifest("css-rev.json")) .pipe(gulp.dest("dist")) // 將map映射文件添加到打包目錄 });gulp-rev-rewrite
根據(jù)rev生成的manifest.json map映射文件, 去替換html文件中的引用名稱,
gulp.task("html", () => { const jsManifest = gulp.src("dist/js-rev.json"); //獲取js映射文件 const cssManifest = gulp.src("dist/css-rev.json"); //獲取css映射文件 return gulp.src("./*.html") .pipe(revRewrite({manifest: jsManifest})) // 把引用的js替換成有版本號的名字 .pipe(revRewrite({manifest: cssManifest})) // 把引用的css替換成有版本號的名字 .pipe(gulp.dest("dist")) });
替換成功
babel是一個 JavaScript 編譯器。我們主要是用將ES6轉(zhuǎn)換成可以在瀏覽器中運行的代碼。而gulp-babel 的用法、功能和babel 是一樣的。
先運行 npm install --save-dev gulp-babel @babel/core @babel/preset-env @babel/plugin-transform-runtime,裝好babel。
const babel = require("gulp-babel"); gulp.task("js", () => gulp.src("src/app.js") .pipe(babel({ presets: ["@babel/env"], plugins: ["@babel/transform-runtime"] })) .pipe(gulp.dest("dist")) );gulp-sourcemaps
找到編譯源文件,方便調(diào)試源碼。
const sourcemaps = require("gulp-sourcemaps"); gulp.task("js", () => gulp.src("src/app.js") .pipe(sourcemaps.init()) .pipe(babel({ presets: ["@babel/env"], plugins: ["@babel/transform-runtime"] })) .pipe(sourcemaps.write(".")) .pipe(gulp.dest("dist")) );gulp-concat
合并js文件
const concat = require("gulp-concat"); gulp.task("js", function() { return gulp.src(["./src/app.js", "./src/app2.js"]) .pipe(concat("app.js")) .pipe(gulp.dest("dist")); });CSS相關(guān) gulp-postcss
CSS預(yù)處理器。
const postcss = require("gulp-postcss"); const autoprefixer = require("autoprefixer"); //添加css兼容性寫法 gulp.task("css", function () { return gulp.src("./src/*.css") .pipe(postcss([ autoprefixer({ browsers: [ ">1%", "last 4 versions", "Firefox ESR", "not ie < 9", "iOS >= 8", "Android > 4.4" ], flexbox: "no-2009", }) ])) .pipe(gulp.dest("./dest")); });gulp-clean-css
壓縮CSS
const cleanCSS = require("gulp-clean-css"); gulp.task("css", () => { return gulp.src("styles/*.css") .pipe(cleanCSS({compatibility: "ie8"})) .pipe(gulp.dest("dist")); });HTML相關(guān) gulp-inline-source
將引用的js、css文件,插入html中,變成內(nèi)聯(lián)式引用。
const inlinesource = require("gulp-inline-source"); gulp.task("html", function () { return gulp.src("./*.html") .pipe(inlinesource({ compress: false //是否壓縮成一行,默認(rèn)為true壓縮 })) .pipe(gulp.dest("./out")); });gulp-htmlmin
壓縮html
const htmlmin = require("gulp-htmlmin"); gulp.task("minify", () => { return gulp.src("src/*.html") .pipe(htmlmin({ removeComments: true, //去除備注 collapseWhitespace: true //去除空白 })) .pipe(gulp.dest("dist")); });其他 del
刪除文件或文件夾
const del = require("del"); /* 清理一些不是必須的js,css文件 */ gulp.task("clean", function() { return del(["./dist/*.js", "./dist/*.css" ]).then(function() { console.log("delete unnecessary files for firecrackers"); }); });gulp-rename
重命名文件
const rename = require("gulp-rename"); gulp.task("html", function() { .pipe(rename({ dirname: ".", // 路徑名 basename: "index", // 主文件名 prefix: "pre-", // 前綴 suffix: "-min", // 后綴 extname: ".html" // 擴展名 })) .pipe(gulp.dest("dist")) });其他鏈接
案例地址:https://github.com/raoenhui/gulpExample.git
原文地址:https://raoenhui.github.io/js/2019/03/03/gulp
Happy coding .. :)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/109297.html
摘要:目前正在開發(fā)一個系統(tǒng),對于前端模塊化與打包這塊出現(xiàn)了一些選擇。采用模塊化及打包由于項目比較小,稍微了解后,覺得沒必要采用。組件化,目前比較流行的如等。項目較小需要交互更新頁面的并不多,沒有采用。 目前正在開發(fā)一個python markdown wiki系統(tǒng),對于前端模塊化與打包這塊出現(xiàn)了一些選擇。1、采用webpack模塊化及打包由于項目比較小,稍微了解后,覺得沒必要采用webpack...
摘要:目前正在開發(fā)一個系統(tǒng),對于前端模塊化與打包這塊出現(xiàn)了一些選擇。采用模塊化及打包由于項目比較小,稍微了解后,覺得沒必要采用。組件化,目前比較流行的如等。項目較小需要交互更新頁面的并不多,沒有采用。 目前正在開發(fā)一個python markdown wiki系統(tǒng),對于前端模塊化與打包這塊出現(xiàn)了一些選擇。1、采用webpack模塊化及打包由于項目比較小,稍微了解后,覺得沒必要采用webpack...
摘要:前兩者定位是工具,則是種模塊化解決方案。這四個都是模塊化的方案。類型默認(rèn)值如果該項被設(shè)置為,那么將會以方式返回而不是文件的形式。整個工程壓縮完需要分鐘以上,使用緩存后只需要秒鐘。 gulp是什么? 一個自動化構(gòu)建工具,基于nodejs的自動任務(wù)運行器。 為什么要使用它? 易于使用,易于學(xué)習(xí)。它能自動化地完成javascript/coffee/sass/less/html/image/c...
摘要:生成的文件如下由于給文件添加了哈希值,所以每次編譯出來的和都是不一樣的,這會導(dǎo)致有很多冗余文件,所以我們可以每次在生成文件之前,先將原來的文件全部清空。中也有做這個工作的插件,因此我們可以在編譯壓縮添加哈希值之前先將原文將清空。 原文鏈接:http://mrzhang123.github.io/2016/09/07/gulpUse/項目鏈接:https://github.com/MrZ...
摘要:常見前端構(gòu)建工具的分類和對比是附帶的包管理器,是內(nèi)置的一個功能,允許在文件里面使用字段定義任務(wù)在這里,一個屬性對應(yīng)一段腳本,原理是通過調(diào)用去運行腳本命令。 前文 端技術(shù)范圍不斷發(fā)展,前端開發(fā)不僅限于直接編寫html,css和javascript,Web應(yīng)用日益龐大,代碼也更加龐大,因此許多新的思想(例如模塊化和工程化等)和框架(React和Vue等),以及新的語言(Es6 TypeSc...
閱讀 2153·2021-10-12 10:11
閱讀 851·2021-10-09 09:41
閱讀 3773·2021-09-09 11:37
閱讀 1950·2021-09-08 10:41
閱讀 2647·2019-08-30 12:58
閱讀 2376·2019-08-30 10:58
閱讀 1286·2019-08-26 13:40
閱讀 4123·2019-08-26 13:36