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

JavaScript webpack5配置及使用基本介紹

 更新時間:2022年09月05日 10:25:32   作者:小綿楊Yancy  
webpack 是一個現代 JavaScript 應用程序的靜態(tài)模塊打包器(module bundler)。這篇文章主要介紹了JavaScript webpack5配置及使用基本介紹

一、webpack

1.1 簡介

在最原始的前端開發(fā)中,我們引入js和css等文件都是通過手動地在html中插入script和link標簽來達到引用的目的,不僅繁瑣,每個文件都需要單獨發(fā)一次請求,而且容易發(fā)生變量沖突的問題。

于是提出了JavaScript模塊化的概念,依次出現了AMD、CommonJS、CMD、ES6模塊化等解決方案。

但是事實上,我們工程使用模塊化開發(fā)是不能直接運行在瀏覽器上的,例如許多npm模塊都是使用的CommonJS的語法,瀏覽器并不支持。

此時便到了模塊打包工具出場的時候了,它的任務就是解決模塊間的依賴,并將項目打包成瀏覽器能夠識別的JS文件。

目前社區(qū)流行的打包工具有Webpack、Parcel、Rollup等。

如果你使用過vue-cli或者create-ract-app等腳手架,那么其實你已經用過webpack了,因為他們都是基于webpack的二次封裝,所以,掌握了webpack的原理,能夠更好地去開發(fā)vue和react工程項目。

1.2 五大核心概念

項目中webpack的配置文件是位于根目錄的:webpack.config.js

entry (入口)

入口起點(entry point)指示 webpack 應該使用哪個模塊,來作為構建其內部依賴圖的開始,例如vue項目中的main.js就是打包時的入口文件。

module.exports = {
  entry: './src/main.js'
};

項目中的所有依賴都應該直接或者間接地與入口文件關聯起來,例如我們都是在main.js中引入外部模塊(axios、router、elementUI等)。

output (出口)

output 屬性告訴 webpack 在哪里輸出它所創(chuàng)建的 bundles,以及如何命名這些文件,默認值為 ./dist。

const path = require('path');
module.exports = {
  entry: './src/main.js',
  output: {
  	//__dirname是當前目錄根目錄
    path: path.resolve(__dirname, 'dist'),
    filename: 'bundle.js'
  }
};
  • ouput的path屬性決定了打包好的文件的生成位置,默認是./dist,如果沒有,webpack會自動創(chuàng)建這個目錄。
  • ouput的filename屬性決定了打包文件的名稱。

loader

loader 讓 webpack 能夠去處理那些非 JavaScript 文件(例如圖片,css文件、vue文件等,webpack 自身只理解 JavaScript)。

loader 可以將所有類型的文件轉換為 webpack 能夠處理的有效模塊,然后你就可以利用 webpack 的打包能力,對它們進行處理。

module.exports = {
  //...
  module: {
    rules: [
      { test: /\.css$/, use: ['style-loader','css-loader'] }
    ]
  }
};

在 webpack 配置中定義 loader 時,要定義在 module.rules 中,其中test屬性是需要匹配的文件名的正則,use屬性是對應的loader,可以是多個(數組)。

例如上面的style-loader和css-loader就是處理js中引入的css文件(如果直接在js中引入css文件,是會報錯的)。

plugin (插件)

oader 被用于轉換某些類型的模塊,而插件則可以用于執(zhí)行范圍更廣的任務。

插件的范圍包括,從打包優(yōu)化和壓縮,一直到重新定義環(huán)境中的變量,插件增強了webpack的功能。

要使用插件,對于webpack內置的插件,我們通過引入webpack然后直接訪問內置插件即可,對于外部插件,我們需要先安裝,然后require引入,然后在plugin數組引入插件(new)實例。

const HtmlWebpackPlugin = require('html-webpack-plugin'); // 通過 npm 安裝
const webpack = require('webpack'); // 用于訪問內置插件
const config = {
  module: {
    rules: [
      //...
    ]
  },
  plugins: [
    new HtmlWebpackPlugin({template: './src/index.html'})
  ]
};
module.exports = config;

上面的html-webpack-plugin插件就是根據模板(template)頁面在打包的目錄中自動生成一個對應的html文件,并且自動插入打包生成js文件的script標簽(正常webpack打包并不會生成html文件)。

mode (模式)

  • 開發(fā)模式(development):優(yōu)化打包速度,優(yōu)化代碼調試。
  • 生產模式(production):優(yōu)化打包速度,優(yōu)化代碼運行的性能

module.exports = {
  mode: 'production'
};

即打包的模式不同,那么webpack對于打包代碼的優(yōu)化策略也不一樣。

二、配置及使用

我們來搭建一個非常簡單的webpack項目??。

項目結構

接著我們創(chuàng)建基本的項目結構和文件??。

my-webpack-demo
    ├── src
    |    └── index.js(入口文件)
    ├── utils
    |    └── time.js(時間工具)
    ├── package-lock.json
    ├── package.json
    ├── webpack.config.js(webpack配置)

其中utils下的time.js負責生成當前時間 time.js:

var time = new Date();
var m = time.getMonth() + 1;
var t = time.getFullYear() + "-" + m + "-" + time.getDate() + " " + time.getHours() + ":" + time.getMinutes() + ":" + time.getSeconds();
module.exports = {
  now: t,
};

入口文件index.js:

import { now } from "../utils/time.js";
document.write("現在是: " + now);

webpack配置文件webpack.config.js:

module.exports = {
  entry: "./src/index.js",
  mode: "development",
  output: {
    filename: "index.js",
  },
};

我們在終端執(zhí)行打包命令:

此時webpack自動在項目中創(chuàng)建了dist目錄,并生成了打包好的index.js文件,那么我們如何驗證index.js文件是否有效呢?

使用html-webpack-plugin

由于webpack并不會自動生成html文件,還記得上面的html-webpack-plugin插件嗎?

通過npm安裝:

在配置文件中引入:

const HtmlWebpackPlugin = require("html-webpack-plugin"); // 通過 npm 安裝
module.exports = {
  entry: "./src/index.js",
  mode: "development",
  output: {
    filename: "index.js",
  },
  plugins: [new HtmlWebpackPlugin({ template: "./src/index.html", scriptLoading: "blocking" })],
};

記得在src下創(chuàng)建index.html模板:

歐克!我們再次執(zhí)行打包命令npx webpack ??。

可以看到,在dist目錄下不僅生成了index.js,還有index.html,我們在瀏覽器中打開它???。

time.js成功生效咯 ?!

三、寫在最后

我們完成了一個非常簡單的webpack項目,你是否發(fā)現了這和vue項目的打包流程十分相似呢?

只是vue-cli的功能是十分強大的,例如可以解析vue文件,熱更新等等……

所以這也驗證了開始說的,vue-cli是對webpack的二次封裝,封裝了許多l(xiāng)oader和plugin,并且配置好了入口,出口等配置信息,我們可以拿來就用。

到此這篇關于JavaScript webpack5配置及使用基本介紹的文章就介紹到這了,更多相關JS webpack5內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論