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