一、Plugin解決了什么問(wèn)題
1、提高靈活性和可擴(kuò)展性
Plugin機(jī)制使得系統(tǒng)的功能可以按需動(dòng)態(tài)加載,可以滿足各種業(yè)務(wù)需求,提高了系統(tǒng)的靈活性和可擴(kuò)展性。
2、降低復(fù)雜度
Plugin通過(guò)將不同功能模塊拆分成不同的插件,可以使系統(tǒng)更易于管理,避免過(guò)多的耦合和依賴關(guān)系,降低了系統(tǒng)的復(fù)雜度。
3、提高可重用性
Plugin模塊可以被多個(gè)應(yīng)用程序或系統(tǒng)所共享使用,可以減少代碼的重復(fù)編寫(xiě),提高了可重用性。
4、簡(jiǎn)化維護(hù)
Plugin可以獨(dú)立開(kāi)發(fā)、測(cè)試和部署,可以獨(dú)立地進(jìn)行修改和更新,能夠簡(jiǎn)化系統(tǒng)的維護(hù)工作。
5、提高安全性
Plugin可以提供額外的安全保障,可以對(duì)系統(tǒng)的功能進(jìn)行更精細(xì)的控制和管理,增強(qiáng)了系統(tǒng)的安全性。
二、Plugin概述
1、概念
Plugin(Plug-in)是一種計(jì)算機(jī)應(yīng)用程序,它和主應(yīng)用程序互相交互,以提供特定的功能。是一種遵循一定規(guī)范的應(yīng)用程序接口編寫(xiě)出來(lái)的程序,只能運(yùn)行在程序規(guī)定的系統(tǒng)下,因?yàn)槠湫枰{(diào)用原純凈系統(tǒng)提供的函數(shù)庫(kù)或者數(shù)據(jù)。webpack中的plugin也是如此,plugin賦予其各種靈活的功能,例如打包優(yōu)化、資源管理、環(huán)境變量注入等,它們會(huì)運(yùn)行在?webpack?的不同階段(鉤子 / 生命周期),貫穿了webpack整個(gè)編譯周期。
目的在于解決loader無(wú)法實(shí)現(xiàn)的其他事。
2、配置方式
這里講述文件的配置方式,一般情況,通過(guò)配置文件導(dǎo)出對(duì)象中plugins屬性傳入new實(shí)例對(duì)象。如下所示:
const HtmlWebpackPlugin = require('html-webpack-plugin'); // 通過(guò) npm 安裝const webpack = require('webpack'); // 訪問(wèn)內(nèi)置的插件module.exports = { ... plugins: [ new webpack.ProgressPlugin(), new HtmlWebpackPlugin({ template: './src/index.html' }), ],};
3、特性
其本質(zhì)是一個(gè)具有apply方法javascript對(duì)象,apply方法會(huì)被webpack compiler調(diào)用,并且在整個(gè)編譯生命周期都可以訪問(wèn)compiler對(duì)象。
const pluginName = 'ConsoleLogOnBuildWebpackPlugin';class ConsoleLogOnBuildWebpackPlugin { apply(compiler) { compiler.hooks.run.tap(pluginName, (compilation) => { console.log('webpack 構(gòu)建過(guò)程開(kāi)始!'); }); }}module.exports = ConsoleLogOnBuildWebpackPlugin;
compiler hook的tap方法的名列前茅個(gè)參數(shù),應(yīng)是駝峰式命名的插件名稱,關(guān)于整個(gè)編譯生命周期鉤子,有如下:
entry-option :初始化 optioncompile: 真正開(kāi)始的編譯,在創(chuàng)建 compilation 對(duì)象之前compilation :生成好了 compilation 對(duì)象make:從 entry 開(kāi)始遞歸分析依賴,準(zhǔn)備對(duì)每個(gè)模塊進(jìn)行 buildafter-compile: 編譯 build 過(guò)程結(jié)束emit :在將內(nèi)存中 assets 內(nèi)容寫(xiě)到磁盤(pán)文件夾之前after-emit :在將內(nèi)存中 assets 內(nèi)容寫(xiě)到磁盤(pán)文件夾之后done: 完成所有的編譯過(guò)程failed: 編譯失敗的時(shí)候4、機(jī)制和原理
應(yīng)用軟件提供使插件能夠應(yīng)用的各項(xiàng)服務(wù),其中包括提供加載方式,使插件可以加載到應(yīng)用程序和網(wǎng)絡(luò)傳輸協(xié)議中,從而和插件進(jìn)行數(shù)據(jù)交換。插件必須依賴于應(yīng)用程序才能發(fā)揮自身功能,僅靠插件是無(wú)法正常運(yùn)行的。相反地,應(yīng)用程序并不需要依賴插件就可以運(yùn)行,這樣一來(lái),插件就可以加載到應(yīng)用程序上并且動(dòng)態(tài)更新而不會(huì)對(duì)應(yīng)用程序造成任何改變。
簡(jiǎn)單來(lái)說(shuō)插件技術(shù)是能通過(guò)在軟件的設(shè)計(jì)和研發(fā)過(guò)程中把軟件的需求和功能進(jìn)行劃分,使程序分為兩個(gè)主要部分主程序和插件。把基礎(chǔ)的功能要求設(shè)計(jì)在主程序中,另外,主程序還提供與插件的接口,使相應(yīng)的插件能夠按一定的規(guī)則進(jìn)行數(shù)據(jù)交換,從而實(shí)現(xiàn)一些功能;而插件則是一個(gè)個(gè)實(shí)現(xiàn)部分功能的組件,這樣通過(guò)增減插件或修改插件內(nèi)部功能來(lái)調(diào)整軟件的功能,由于插件是對(duì)獨(dú)立的部分,可以獨(dú)立進(jìn)行編輯。從而實(shí)現(xiàn)軟件功能的擴(kuò)展和不斷改進(jìn)。
公開(kāi)應(yīng)用程序接口提供一個(gè)標(biāo)準(zhǔn)的界面,允許其他人編寫(xiě)插件和應(yīng)用程序互動(dòng)。一個(gè)穩(wěn)定的應(yīng)用程序接口會(huì)允許 其他插件正常運(yùn)行即使其最初的版本有所變動(dòng),也會(huì)支持插件延長(zhǎng)老舊的應(yīng)用程序的使用壽命。Adobe Photoshop 和After Effects的插件應(yīng)用程序接口逐漸成為標(biāo)準(zhǔn),并且被一些和它們競(jìng)爭(zhēng)的應(yīng)用程序部分采納。
5、常見(jiàn)的Plugin
延伸閱讀1:插件的種類
文本插件:類似批處理命令的簡(jiǎn)單插件。腳本插件:使用一種特殊的腳本語(yǔ)言來(lái)實(shí)現(xiàn)的插件。程序插件:利用已有的程序開(kāi)發(fā)環(huán)境來(lái)制作插件。