亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Node.js?Webpack常見的模式詳解

 更新時(shí)間:2022年10月28日 09:27:56   作者:coderHing  
這篇文章主要介紹了Node.js?Webpack常見的模式,Webpack的另一個(gè)核心是Plugin?,Plugin是可以用于執(zhí)行更加廣泛的任務(wù)如打包優(yōu)化資源管理?環(huán)境變量注入等,需要的朋友可以參考下

 一、認(rèn)識(shí)插件 Plugin

認(rèn)識(shí)Plugin

Webpack的另一個(gè)核心是Plugin 官方有這樣一段話對(duì)Plugin的描述

While loaders are used to transform certain types of modules, plugins can be leveraged to perform a wider range of tasks like bundle optimization,asset management and injection of environment variables

翻譯過來就是:

loader是用來 特性的模塊類型 進(jìn)行轉(zhuǎn)換

Plugin是可以用于 執(zhí)行更加廣泛的任務(wù) 如 打包優(yōu)化 資源管理 環(huán)境變量注入等

二、CleanWebpackPlugin

我們每次修改一些配置 重新打包時(shí) 都需要手動(dòng)刪除 dist文件夾

可以借助這個(gè)插件來幫助我們完成

首先 安裝這個(gè)插件

npm install clean-webpack-plugin -D

之后在插件中配置

const ?{CleanWebpackPlugin} = require('clean-webpack-plugin')

module.exports = {
????// 其他省略 ...
????plugins:[
????????new CleanWebpackPlugin()
????]
}

三、HtmlWebpackPlugin

另外還有一個(gè)不太規(guī)范的地方:

我們的HTML文件是編寫在根目錄的,最終打包的dist文件夾中沒有index.html文件的

在進(jìn)行項(xiàng)目部署時(shí) 必須也是需要有對(duì)應(yīng)的入口文件index.html

所以我們也需要對(duì)index.html進(jìn)行打包管理

對(duì)HTML進(jìn)行打飽處理 可以使用另一個(gè)插件 HtmlWebpackPlugin

npm install html-webpack-plugin -D
const HtmlWebpackPlugin = require('html-webpack-plugin')

module.exports = {
????// 其他省略 ...
????plugins:[
????????new HtmlWebpackPlugin({
????????????title:"電商項(xiàng)目"
????????})
????]
}

生成index.html分析

自動(dòng)在dist文件中 生成了一個(gè)index.html文件

該文件中也自動(dòng)添加了我們打包的js文件

這個(gè)文件是如何生成的?

默認(rèn)情況下根據(jù)ejs的一個(gè)模塊來生成的

在html-webpack-plugin的源碼中,有一個(gè)defaults_index.ejs模塊

自定義HTML模版

如果我們想在自己的模塊中加入一些比較特別的內(nèi)容:

如添加一個(gè) noscript標(biāo)簽 在用戶的JS被關(guān)閉時(shí) 給予響應(yīng)的提示

如在開發(fā)vue或react項(xiàng)目時(shí) 需要一個(gè)可以掛在后續(xù)組件的跟標(biāo)簽<div id="app"></div>

自定義模版數(shù)據(jù)填充

在配置HtmlWebpackPlugin時(shí) 我們可以添加如下配置

Temolate: 指定我們曜使用的模塊所在的路徑

title:在進(jìn)行HtmlWebpackPlugin.options.title讀取時(shí) 就會(huì)讀到該信息

四、DefinePlugin

DefinePlugin的介紹

這個(gè)時(shí)候編譯還會(huì)報(bào)錯(cuò) 因?yàn)槲覀兊哪K中還是用到一個(gè) BASE_URL的常量:

 

這是因?yàn)樵诰幾g template模塊時(shí) 有一個(gè) BASE_URL:

<link rel="icon" href="<%=BASE_URL %">favicon.ico">

但是我們并沒有設(shè)置過這歌常量值,所以會(huì)出現(xiàn)沒有定義的錯(cuò)誤

這個(gè)時(shí)候我們可以使用DefinePlugin插件;

DefinePlugin的使用

DefinePlugin允許在編譯時(shí)創(chuàng)建配置的全局常量 是一個(gè)webpack內(nèi)置的插件(不需要單獨(dú)安裝):

const {DefinePlugin} = require('webpack')

module.exports = {
????// 其他省略
????plugins:[
????????new DefinePlugin({
????????????BASE_URL:'"./"'
????????})
????]
}

五、Mode模式配置

Mode配置

Mode配置選項(xiàng) 可以告知webpack使用相應(yīng)模式的內(nèi)置優(yōu)化

默認(rèn)值是production(什么都不設(shè)置的情況下)

可選值有:'none'|'development'|'production'

到此這篇關(guān)于Node.js Webpack常見的模式的文章就介紹到這了,更多相關(guān)Node.js Webpack模式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Node.js?操作本地文件及深入了解fs內(nèi)置模塊

    Node.js?操作本地文件及深入了解fs內(nèi)置模塊

    這篇文章主要介紹了Node.js?操作本地文件及深入了解fs內(nèi)置模塊,node.js作為服務(wù)端應(yīng)用,肯定少不了對(duì)本地文件的操作,像創(chuàng)建一個(gè)目錄、創(chuàng)建一個(gè)文件、讀取文件內(nèi)容等都是我們開發(fā)中經(jīng)常需要用到的功能
    2022-09-09
  • Node.js 在本地生成日志文件的方法

    Node.js 在本地生成日志文件的方法

    這篇文章主要介紹了Node.js 在本地生成日志文件的方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-02-02
  • nodejs的安裝使用與npm的介紹

    nodejs的安裝使用與npm的介紹

    Node.js是一個(gè)Javascript運(yùn)行環(huán)境(runtime environment),發(fā)布于2009年5月,由Ryan Dahl開發(fā),實(shí)質(zhì)是對(duì)Chrome V8引擎進(jìn)行了封裝。本文詳細(xì)介紹了Node.js的安裝和使用,需要的朋友可以參考下
    2019-09-09
  • nvm安裝方法以及安裝后node不能使用解決

    nvm安裝方法以及安裝后node不能使用解決

    在我們的日常開發(fā)中經(jīng)常會(huì)遇到這種情況,手上有好幾個(gè)項(xiàng)目,每個(gè)項(xiàng)目的需求不同,進(jìn)而不同項(xiàng)目必須依賴不同版的NodeJS運(yùn)行環(huán)境,nvm應(yīng)運(yùn)而生,這篇文章主要給大家介紹了關(guān)于nvm安裝方法以及安裝后node不能使用解決的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • 深入理解Node.js中的進(jìn)程管理

    深入理解Node.js中的進(jìn)程管理

    這篇文章主要介紹了Node.js中進(jìn)程管理的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),相信對(duì)大家的學(xué)習(xí)或者工作具有一定的參考價(jià)值,需要的朋友們下面來一起看看吧。
    2017-03-03
  • node.js 基于 STMP 協(xié)議和 EWS 協(xié)議發(fā)送郵件

    node.js 基于 STMP 協(xié)議和 EWS 協(xié)議發(fā)送郵件

    這篇文章主要介紹了node.js 基于 STMP 協(xié)議和 EWS 協(xié)議發(fā)送郵件的示例,幫助大家更好的理解和使用node.js,感興趣的朋友可以了解下
    2021-02-02
  • nodejs版本管理工具nvm的安裝與使用小結(jié)

    nodejs版本管理工具nvm的安裝與使用小結(jié)

    在項(xiàng)目開發(fā)過程中,使用到vue框架技術(shù),需要安裝node下載項(xiàng)目依賴,本文主要介紹了nodejs版本管理工具nvm的安裝與使用小結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-01-01
  • Node.js中MongoDB更新數(shù)據(jù)的兩種方法

    Node.js中MongoDB更新數(shù)據(jù)的兩種方法

    本文主要介紹了Node.js中MongoDB更新數(shù)據(jù)的兩種方法,主要包括使用原生的 MongoDB 驅(qū)動(dòng)程序或者使用 Mongoose 來更新 MongoDB 數(shù)據(jù),
    2023-12-12
  • 解讀node.js中的path路徑模塊

    解讀node.js中的path路徑模塊

    這篇文章主要介紹了解讀node.js中的path路徑模塊,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • npm?install總是卡住不動(dòng)問題的解決辦法

    npm?install總是卡住不動(dòng)問題的解決辦法

    在我們安裝完Node.js之后,需要使用npm命令來安裝一些工具,下面這篇文章主要給大家介紹了關(guān)于npm?install總是卡住不動(dòng)問題的解決辦法,需要的朋友可以參考下
    2022-05-05

最新評(píng)論