国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > Plugin解決了什么問題?

Plugin解決了什么問題?

來源:千鋒教育
發布人:xqq
時間: 2023-10-13 09:51:03 1697161863

一、Plugin解決了什么問題

1、提高靈活性和可擴展性

Plugin機制使得系統的功能可以按需動態加載,可以滿足各種業務需求,提高了系統的靈活性和可擴展性。

2、降低復雜度

Plugin通過將不同功能模塊拆分成不同的插件,可以使系統更易于管理,避免過多的耦合和依賴關系,降低了系統的復雜度。

3、提高可重用性

Plugin模塊可以被多個應用程序或系統所共享使用,可以減少代碼的重復編寫,提高了可重用性。

4、簡化維護

Plugin可以獨立開發、測試和部署,可以獨立地進行修改和更新,能夠簡化系統的維護工作。

5、提高安全性

Plugin可以提供額外的安全保障,可以對系統的功能進行更精細的控制和管理,增強了系統的安全性。

二、Plugin概述

1、概念

Plugin(Plug-in)是一種計算機應用程序,它和主應用程序互相交互,以提供特定的功能。是一種遵循一定規范的應用程序接口編寫出來的程序,只能運行在程序規定的系統下,因為其需要調用原純凈系統提供的函數庫或者數據。webpack中的plugin也是如此,plugin賦予其各種靈活的功能,例如打包優化、資源管理、環境變量注入等,它們會運行在?webpack?的不同階段(鉤子 / 生命周期),貫穿了webpack整個編譯周期。

目的在于解決loader無法實現的其他事。

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方法的名列前茅個參數,應是駝峰式命名的插件名稱,關于整個編譯生命周期鉤子,有如下:

entry-option :初始化 optioncompile: 真正開始的編譯,在創建 compilation 對象之前compilation :生成好了 compilation 對象make:從 entry 開始遞歸分析依賴,準備對每個模塊進行 buildafter-compile: 編譯 build 過程結束emit :在將內存中 assets 內容寫到磁盤文件夾之前after-emit :在將內存中 assets 內容寫到磁盤文件夾之后done: 完成所有的編譯過程failed: 編譯失敗的時候

4、機制和原理

應用軟件提供使插件能夠應用的各項服務,其中包括提供加載方式,使插件可以加載到應用程序和網絡傳輸協議中,從而和插件進行數據交換。插件必須依賴于應用程序才能發揮自身功能,僅靠插件是無法正常運行的。相反地,應用程序并不需要依賴插件就可以運行,這樣一來,插件就可以加載到應用程序上并且動態更新而不會對應用程序造成任何改變。

簡單來說插件技術是能通過在軟件的設計和研發過程中把軟件的需求和功能進行劃分,使程序分為兩個主要部分主程序和插件。把基礎的功能要求設計在主程序中,另外,主程序還提供與插件的接口,使相應的插件能夠按一定的規則進行數據交換,從而實現一些功能;而插件則是一個個實現部分功能的組件,這樣通過增減插件或修改插件內部功能來調整軟件的功能,由于插件是對獨立的部分,可以獨立進行編輯。從而實現軟件功能的擴展和不斷改進。

公開應用程序接口提供一個標準的界面,允許其他人編寫插件和應用程序互動。一個穩定的應用程序接口會允許 其他插件正常運行即使其最初的版本有所變動,也會支持插件延長老舊的應用程序的使用壽命。Adobe Photoshop 和After Effects的插件應用程序接口逐漸成為標準,并且被一些和它們競爭的應用程序部分采納。

5、常見的Plugin

延伸閱讀1:插件的種類

文本插件:類似批處理命令的簡單插件。腳本插件:使用一種特殊的腳本語言來實現的插件。程序插件:利用已有的程序開發環境來制作插件。
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT