欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript自定義Webpack配置實(shí)現(xiàn)流程介紹

 更新時間:2022年10月19日 16:48:09   作者:橘貓吃不胖~  
本系列主要整理前端面試中需要掌握的知識點(diǎn)。本節(jié)介紹webpack如何優(yōu)化前端性能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

1 初始化并創(chuàng)建要被打包的文件

首先創(chuàng)建文件夾webpack-demo(隨便起一個),用來演示打包過程。在該文件夾下終端運(yùn)行命令,對項(xiàng)目進(jìn)行初始化操作,對包進(jìn)行管理:

npm init # 輸入命令后一直敲回車即可
npm init -y # -y是yes的意思,在初始化時省去敲回車的步驟

命令成功運(yùn)行之后,該文件夾下出現(xiàn)了package.json文件,文件內(nèi)容具體如下:

{
  "name": "webpack-demo",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [],
  "author": "",
  "license": "ISC"
}

然后在本地安裝webpackwebpack-cli,執(zhí)行以下命令:

npm install webpack webpack-cli --save-dev

該命令執(zhí)行完成之后,在當(dāng)前目錄下出現(xiàn)了node_modules文件夾和package-lock.json文件,目錄結(jié)構(gòu)如下:

webpack-demo文件夾下創(chuàng)建文件夾src,在src下創(chuàng)建兩個文件,index.jshello.js,目錄結(jié)構(gòu)如下:

hello.js文件中編寫如下代碼:

function hello() {
    console.log("hello");
}
export default hello;

index.js文件中編寫如下代碼:

import hello from "./hello";
hello();

到這一步我們的準(zhǔn)備工作就完成了,接下來在該示例上操作。

2 命令行配置

webpack-cli給我們提供了豐富的終端命令行指令,可以通過以下命令查看:

npx webpack --help

我們看到有很多命令可以幫助我們進(jìn)行配置,接下來我們演示幾個。

# --entry 指定了入口文件為index.js
# --mode 指定模式為production生產(chǎn)環(huán)境
npx webpack --entry ./src/index.js --mode production

運(yùn)行該命令之后,我們可以看到目錄新出現(xiàn)了dist文件夾,文件夾中有main.js文件,該文件就是我們打包之后的文件。

那么dist文件夾的名字和main.js文件的名字可以自己定義嗎?答案是可以,但是我們需要在命令行中輸入其他的參數(shù)。

到這里我們發(fā)現(xiàn),命令行不方便也不直觀,而且不能保存我們的一些配置,因此webpack為我們提供了通過自定義配置文件的方式幫助我們自定義配置參數(shù)。

3 配置文件配置

我們在webpack-demo文件夾中新建文件webpack.config.js文件,這個文件名不能隨意起,因?yàn)?code>webpack會自動讀取文件,在該文件中配置entryoutput制定輸入和輸出的文件:

module.exports = {
    entry: "./src/index.js", // 設(shè)置入口文件
    output: {
        filename: "bundle.js", // 指定輸出的文件
        path: "./dist", // 指定輸出的路徑
    }
}

配置完成之后我們在終端運(yùn)行命令來打包文件:

npx webpack

結(jié)果我們可以看到,終端為我們報了錯,提示我們輸出路徑必須是一個絕對路徑。那么我們可以通過node中的path模塊來獲得當(dāng)前文件的路徑,通過該路徑來設(shè)置輸出路徑:

const path = require("path");
module.exports = {
    entry: "./src/index.js", // 設(shè)置入口文件
    output: {
        filename: "bundle.js", // 指定輸出的文件
        // path.resolve()把一個路徑或路徑片段的序列解析為一個絕對路徑
        // __dirname是當(dāng)前文件所在的目錄
        path: path.resolve(__dirname, "./dist"), // 指定輸出的路徑
    }
}

我們再執(zhí)行npx webpack,我們發(fā)現(xiàn)打包成功了,不過終端提示我們還應(yīng)該設(shè)置一下mode,我們在配置文件后添加上mode即可。

const path = require("path");
module.exports = {
    entry: "./src/index.js", // 設(shè)置入口文件
    output: {
        filename: "bundle.js", // 指定輸出的文件
        // path.resolve()把一個路徑或路徑片段的序列解析為一個絕對路徑
        // __dirname是當(dāng)前文件所在的目錄
        path: path.resolve(__dirname, "./dist"), // 指定輸出的路徑
    },
    mode: "production" // 模式:生產(chǎn)環(huán)境
}

打包之后,我們可以看到dist文件夾下面出現(xiàn)了bundle.js文件,該文件就是我們打包之后的文件。

到此這篇關(guān)于JavaScript自定義Webpack配置實(shí)現(xiàn)流程介紹的文章就介紹到這了,更多相關(guān)JavaScript自定義Webpack 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • ES6 Generator函數(shù)的應(yīng)用實(shí)例分析

    ES6 Generator函數(shù)的應(yīng)用實(shí)例分析

    這篇文章主要介紹了ES6 Generator函數(shù)的應(yīng)用,結(jié)合實(shí)例形式分析了ES6 Generator函數(shù)異步操作與異常捕獲相關(guān)使用技巧,需要的朋友可以參考下
    2019-06-06
  • JavaScript中Number的對象解析

    JavaScript中Number的對象解析

    這篇文章主要介紹了JavaScript中Number的對象解析,Number對象是數(shù)值對應(yīng)的包裝對象,可以作為構(gòu)造函數(shù)使用,也可以作為工具函數(shù)使用,感興趣的朋友可以參考一下下面文章內(nèi)容
    2022-08-08
  • 使用Object.defineProperty為對象定義屬性

    使用Object.defineProperty為對象定義屬性

    這篇文章主要為大家介紹了使用Object.defineProperty為對象定義屬性示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • 使用JavaScript平移和縮放圖像的示例代碼

    使用JavaScript平移和縮放圖像的示例代碼

    平移和縮放是查看圖像時常用的功能,我們可以放大圖像以查看更多細(xì)節(jié),進(jìn)行圖像編輯,Dynamsoft Document Viewer是一個用于此目的的SDK,它為文檔圖像提供了一組查看器,在本文中,我們將演示如何使用它來平移和縮放圖像,需要的朋友可以參考下
    2024-08-08
  • JS正則驗(yàn)證郵箱的格式詳細(xì)介紹

    JS正則驗(yàn)證郵箱的格式詳細(xì)介紹

    這篇文章主要介紹了JS正則驗(yàn)證郵箱的格式。需要的朋友可以過來參考下,希望對大家有所幫助
    2013-11-11
  • JS實(shí)現(xiàn)光滑展開合攏的菜單效果代碼

    JS實(shí)現(xiàn)光滑展開合攏的菜單效果代碼

    這篇文章主要介紹了JS實(shí)現(xiàn)光滑展開合攏的菜單效果代碼,涉及JavaScript響應(yīng)鼠標(biāo)事件遍歷并改變頁面元素屬性的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-09-09
  • 解決layui的radio屬性或別的屬性沒顯示出來的問題

    解決layui的radio屬性或別的屬性沒顯示出來的問題

    今天小編就為大家分享一篇解決layui的radio屬性或別的屬性沒顯示出來的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • Javascript中判斷一個值是否為undefined的方法詳解

    Javascript中判斷一個值是否為undefined的方法詳解

    這篇文章給大家詳細(xì)介紹了在Javascript中如何判斷一個值是否為undefined,對大家的日常工作和學(xué)習(xí)很有幫助,下面來一起看看吧。
    2016-09-09
  • javascript十六進(jìn)制數(shù)字和ASCII字符之間的轉(zhuǎn)換方法

    javascript十六進(jìn)制數(shù)字和ASCII字符之間的轉(zhuǎn)換方法

    下面小編就為大家?guī)硪黄猨avascript十六進(jìn)制數(shù)字和ASCII字符之間的轉(zhuǎn)換方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • 微信小程序?qū)崿F(xiàn)的動態(tài)設(shè)置導(dǎo)航欄標(biāo)題功能示例

    微信小程序?qū)崿F(xiàn)的動態(tài)設(shè)置導(dǎo)航欄標(biāo)題功能示例

    這篇文章主要介紹了微信小程序?qū)崿F(xiàn)的動態(tài)設(shè)置導(dǎo)航欄標(biāo)題功能,結(jié)合實(shí)例形式分析了微信小程序使用wx.setNavigationBarTitle接口動態(tài)設(shè)置導(dǎo)航欄標(biāo)題的相關(guān)操作技巧,需要的朋友可以參考下
    2019-01-01

最新評論