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

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

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

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

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

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

命令成功運(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)建兩個(gè)文件,index.jshello.js,目錄結(jié)構(gòu)如下:

hello.js文件中編寫(xiě)如下代碼:

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

index.js文件中編寫(xiě)如下代碼:

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

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

2 命令行配置

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

npx webpack --help

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

# --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為我們提供了通過(guò)自定義配置文件的方式幫助我們自定義配置參數(shù)。

3 配置文件配置

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

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

配置完成之后我們?cè)诮K端運(yùn)行命令來(lái)打包文件:

npx webpack

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

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

我們?cè)賵?zhí)行npx webpack,我們發(fā)現(xiàn)打包成功了,不過(guò)終端提示我們還應(yīng)該設(shè)置一下mode,我們?cè)谂渲梦募筇砑由?code>mode即可。

const path = require("path");
module.exports = {
    entry: "./src/index.js", // 設(shè)置入口文件
    output: {
        filename: "bundle.js", // 指定輸出的文件
        // path.resolve()把一個(gè)路徑或路徑片段的序列解析為一個(gè)絕對(duì)路徑
        // __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)容請(qǐng)搜索腳本之家以前的文章或繼續(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的對(duì)象解析

    JavaScript中Number的對(duì)象解析

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

    使用Object.defineProperty為對(duì)象定義屬性

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

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

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

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

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

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

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

    解決layui的radio屬性或別的屬性沒(méi)顯示出來(lái)的問(wèn)題

    今天小編就為大家分享一篇解決layui的radio屬性或別的屬性沒(méi)顯示出來(lái)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-09-09
  • Javascript中判斷一個(gè)值是否為undefined的方法詳解

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

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

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

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

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

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

最新評(píng)論