溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

webpack4.0各個擊破(10)—— Integration篇

發(fā)布時間:2020-07-01 20:51:54 來源:網(wǎng)絡(luò) 閱讀:1127 作者:大史不說話 欄目:開發(fā)技術(shù)

webpack作為前端最火的構(gòu)建工具,是前端自動化工具鏈最重要的部分,使用門檻較高。本系列是筆者自己的學(xué)習(xí)記錄,比較基礎(chǔ),希望通過問題 + 解決方式的模式,以前端構(gòu)建中遇到的具體需求為出發(fā)點,學(xué)習(xí)webpack工具中相應(yīng)的處理辦法。(本篇中的參數(shù)配置及使用方式均基于webpack4.0版本

webpack4.0中級教程專題

webpack4.0各個擊破(10)—— Integration篇

webpack4.0各個擊破(10)—— Integration篇

一. Integration

下文摘自webpack中文網(wǎng):

首先我們要消除一個常見的誤解,webpack是一個模塊打包工具(module bundler),它不是一個任務(wù)執(zhí)行工具,任務(wù)執(zhí)行器是用來自動化處理開發(fā)中常見任務(wù)的,例如檢查(lint),構(gòu)建(build),測試(test)等。相對于打包器,任務(wù)執(zhí)行器所面對的邏輯問題更為上層,你可以使用上層的工具來管理整個持續(xù)集成(CI),而把打包的部分交給webpack。

webpack在工具鏈中的角色定位是非常清晰的,那么為了與其他流程進(jìn)行合作,就需要使用任務(wù)管理工具來啟動webpack,本文介紹兩種常見的方法。

1. 使用Node-API

webpak暴露了一些方法,使得開發(fā)者可以通過調(diào)用他們而在腳本中啟動webpack,使用的方法較為簡單:

//webpack-node.js
const webpack = require('webpack');
const webpackConfig = require('./webpack.config.html.js');
const cowsay = require('cowsay');

const compiler = webpack(webpackConfig);

compiler.run((err, stats)=>{
   if (!err) {
        console.log(stats.toJson().assets);
        console.log(cowsay.say({text:'Congratulations!'}));
   }

});

運行結(jié)果:
webpack4.0各個擊破(10)—— Integration篇

這里解釋一下上面代碼的基本邏輯,引入了webpack模塊以及webpack.config.html.js的配置文件(從這里就很容易理解為什么webpack的配置文件可以導(dǎo)出為一個函數(shù)或多個配置,它實際上也是作為一個模塊參與到整個運行過程的),通過調(diào)用webpack([Object config])方法得到一個compiler實例,調(diào)用compiler.run方法就啟動了webpack的構(gòu)建功能,run方法的回調(diào)函數(shù)中如果有運行錯誤,可以通過err來獲取,與構(gòu)建過程有關(guān)的信息都掛載在stats對象(例如stats。toJson().assets)。這樣便實現(xiàn)了以非命令行的方式啟動webpack。

2.使用gulp

gulp是基于流的任務(wù)管理工具,實際上webpack的細(xì)分功能使用gulp也可以做到,而且很多功能型插件都會提供針對grunt,gulpwebpack等不同工具的集成方式。gulp的確更適合做宏觀意義上的任務(wù)流管理,還是那句老話,工具是提供便利的,而不是提供束縛的。官方文檔也提供了如下代碼示例:

//gulpfile.js
var gulp = require('gulp');
var webpack = require('webpack-stream');
gulp.task('default',function(){
    return gulp.src('src/entry.js')
        .pipe(webpack({
        //...configs
    })).pipe(gulp.dest('dist/'));
})

二. after webpack

至此,webpack已經(jīng)被集成進(jìn)了自動化工具鏈,開發(fā)者可以按自己的需求來定制構(gòu)建以后需要執(zhí)行的任務(wù),但webpack的使命還沒有結(jié)束,構(gòu)建的結(jié)束距離用戶能夠訪問站點和使用功能還需要非常多的工作要做,有很多問題并不是在構(gòu)建中出現(xiàn)的,但是卻需要在構(gòu)建時加以處理,這個時候開發(fā)者又需要回過頭來為webpack增加配置。

例如很多開發(fā)者最初不理解構(gòu)建過程中為什么要使用hash,chunkhash等占位符來把文件名變得丑陋無比,直到不同版本的產(chǎn)品上線時出現(xiàn)不強制刷新頁面就無法訪問新資源的問題時,才會開始關(guān)注版本更新和緩存策略的問題,然后才會理解為了標(biāo)記版本而啟用hash,為了避免重復(fù)構(gòu)建而使用chunkhash,為了減小體積而使用tree-shaking等等。

三. 商務(wù)吹捧走一波

webpack4.0各個擊破》全系列文章就連載結(jié)束了,感謝您的關(guān)注,希望對你有所幫助,你也可以通過以下方式查看我的其他博文。

博客園地址:https://www.cnblogs.com/dashnowords

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI