Webpack入门教程:从基本概念到优化技巧

简介

Webpack是一个现代JavaScript应用程序的静态模块打包器(module bundler),它能够将项目中的所有依赖项(包括JavaScript、图片、CSS等)打包成一个或多个bundle。这篇文章将带你从Webpack的基本概念开始,逐步深入到安装配置、常用功能和优化技巧。

安装配置

安装Webpack

在开始之前,请确保你已经安装了Node.js和npm。你可以通过npm全局安装Webpack,或者将其作为项目的开发依赖安装。

# 全局安装
npm install -g webpack# 项目开发依赖安装
npm install --save-dev webpack webpack-cli

创建配置文件

Webpack需要一个配置文件(通常是webpack.config.js),来告诉它如何处理你的项目。以下是一个基本的配置文件示例:

const path = require('path');module.exports = {entry: './src/index.js', // 入口文件output: {filename: 'bundle.js', // 输出文件path: path.resolve(__dirname, 'dist') // 输出路径},module: {rules: [{test: /\.js$/, // 匹配.js文件exclude: /node_modules/, // 排除node_modules目录use: 'babel-loader', // 使用babel-loader处理.js文件},{test: /\.css$/, // 匹配.css文件use: ['style-loader', 'css-loader'], // 使用style-loader和css-loader处理.css文件}]}
};

常用功能

模块热替换(HMR)

模块热替换(HMR)可以在应用程序运行时替换、添加或删除模块,而无需重新加载整个页面。要使用HMR,你需要在配置文件中添加devServerhot选项:

const webpack = require('webpack');module.exports = {// ...其他配置devServer: {hot: true // 开启热更新},plugins: [new webpack.HotModuleReplacementPlugin() // webpack5 内置]
};

代码分割

Webpack允许你将代码分割成多个bundle,这些bundle可以按需加载。以下是一个简单的代码分割示例:

// 在index.js中异步加载asyncComponent
import(/* webpackChunkName: "asyncComponent" */ './asyncComponent').then((module) => {const AsyncComponent = module.default;ReactDOM.render(<AsyncComponent />, document.getElementById('root'));
});

多入口配置

Webpack支持多入口配置,这对于大型项目非常有用。你可以为不同的页面或功能模块设置不同的入口点:

module.exports = {entry: {index: './src/pages/index/index.js',album: './src/pages/album/album.js',work: './src/pages/work/work.js'},output: {filename: '[name]-[contenthash:8].bundle.js', // 避免缓存问题path: path.join(__dirname, 'dist')}
};

树摇(Tree Shaking)

Webpack支持ES6模块的tree shaking,这意味着未使用的代码会被去除,减少最终捆绑文件的大小。以下是一个简单的tree shaking示例:

// 在utils.js中
export function add(a, b) {return a + b;
}export function subtract(a, b) {return a - b;
}// 在index.js中只使用add函数
import { add } from './utils';
console.log(add(5, 3));

优化技巧

性能优化 - 代码分离

代码分离(Code Splitting)是webpack一个非常重要的特性,它主要的目的是将代码分离到不同的bundle中,之后我们可以按需加载,或者并行加载这些文件。

// 在需要分割的代码块中使用动态导入
async function loadComponent() {const module = await import('./Component');module.default();
}

插件系统

Webpack支持广泛的插件系统,可以用来优化输出、清理旧的捆绑文件、将文件复制到任意位置等。例如,HtmlWebpackPlugin可以快速创建HTML文件来服务bundles。

const HtmlWebpackPlugin = require('html-webpack-plugin');module.exports = {// ...其他配置plugins: [new HtmlWebpackPlugin({template: './src/index.html'})]
};

环境变量和模式

Webpack允许你设置不同的模式(mode),如development和production,以及使用DefinePlugin来替换代码中的常量,这在设置环境变量时非常有用。

const webpack = require('webpack');module.exports = {mode: 'production', // 设置模式为生产模式plugins: [new webpack.DefinePlugin({'process.env.NODE_ENV': JSON.stringify('production')})]
};

结语

Webpack是一个功能强大的模块打包工具,通过这篇文章,我们介绍了Webpack的基本概念、安装配置、常用功能和优化技巧。希望这能帮助你快速入门Webpack,并在你的项目中有效地使用它。

参考资料

  • Webpack官方文档
  • Babel官方文档
  • React官方文档

请根据你的项目需求和环境,适当调整上述代码和配置。祝你在Webpack的学习之路上越走越远!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/461851.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

再探“构造函数”

文章目录 一. 初始化列表1.1 实现1.2 何时必须使用初始化列表2.3 尽量使用初始化列表 二. 类型转换2.1 内置类型 转换 类类型2.2 explicit&#xff1a;不转换2.3 构造函数多参数2.4 使用隐式转换 2.5 自定义---转换为--->自定义类型 三. 静态成员变量概念在main函数调用私有…

静态路由实现路由互通

静态路由 实现 pc1 ping通 pc2&#xff0c;展示静态路由效果。 默认 pc1 无法ping通 pc2 ar1 ar2 互相添加静态路由 sy Enter system view, return user view with CtrlZ. [ar1]ip route-static 2.2.2.0 255.255.255.0 12.1.1.2 sy Enter system view, return user view wit…

Python爬虫入门篇!

毕设是做爬虫相关的&#xff0c;本来想的是用java写&#xff0c;也写了几个爬虫&#xff0c;其中一个是爬网易云音乐的用户信息&#xff0c;爬了大概100多万&#xff0c;效果不是太满意。之前听说Python这方面比较强&#xff0c;就想用Python试试&#xff0c;之前也没用过Pytho…

【OpenGL】知识点

VAO 和webgl一致 给个完整案例&#xff0c;可以对比 案例&#xff1a;WebGL中VAO调用&#xff0c;是一致的 void prepareSingleBuffer() {//1 准备positions colors数据float positions[] {-0.5f, -0.5f, 0.0f,0.5f, -0.5f, 0.0f,0.0f, 0.5f, 0.0f};float colors[] {1.0f,…

基于NVIDIA NIM平台实现盲人过马路的demo(一)

前言:利用NVIDIA NIM平台提供的大模型进行编辑,通过llama-3.2-90b-vision-instruct模型进行初步的图片检测 step1: 部署大模型到本地,引用所需要的库 import os import requests import base64 import cv2 import time from datetime import datetimestep2: 观看官方使用文…

【大数据学习 | kafka】producer端的回调和ack

主线程将数据放入到本地累加器中record accumulator中进行存储&#xff0c;sender线程会异步的拉取数据到kafka集群中&#xff0c;这个数据拉取并且复制到kafka集群中以后&#xff0c;kafka需要返回给sender线程一个确认应答ack&#xff0c;这个确认应答用于在sender线程中进行…

硅谷甄选(11)角色管理

角色管理模块 10.1 角色管理模块静态搭建 还是熟悉的组件&#xff1a;el-card、el-table 、el-pagination、el-form <template><el-card><el-form :inline"true" class"form"><el-form-item label"职位搜索"><el-…

使用Git进行版本控制的最佳实践

文章目录 Git简介基本概念仓库&#xff08;Repository&#xff09;提交&#xff08;Commit&#xff09;分支&#xff08;Branching&#xff09; 常用命令初始化仓库添加文件提交修改查看状态克隆仓库分支操作合并分支推送更改 最佳实践使用有意义的提交信息定期推送至远程仓库使…

开源模型应用落地-Qwen2.5-7B-Instruct与TGI实现推理加速

一、前言 目前&#xff0c;大语言模型已升级至Qwen2.5版本。无论是语言模型还是多模态模型&#xff0c;均在大规模多语言和多模态数据上进行预训练&#xff0c;并通过高质量数据进行后期微调以贴近人类偏好。在本篇学习中&#xff0c;将集成 Hugging Face的TGI框架实现模型推理…

Halcon-模板匹配(WPF)

halcon的代码 dev_open_window (0, 0, 512, 512, black, WindowHandle) read_image (Image, C:/Users/CF/Desktop/image.jpg) dev_display (Image)draw_rectangle1 (WindowHandle, Row1, Column1, Row2, Column2) gen_rectangle1 (Rectangle, Row1, Column1, Row2, Column2) r…

CSGO: Content-Style Composition in Text-to-Image Generation(代码的复现)

文章目录 CSGO简介论文的代码部署需要下载的模型权重&#xff1a;复现中存在的一些问题 推理代码生成结果示意图 CSGO简介 CSGO: Content-Style Composition in Text-to-Image Generation&#xff08;风格迁移&#xff09; 本文是一篇风格迁移的论文&#xff1a;将内容参考图像…

安卓13默认连接wifi热点 android13默认连接wifi

总纲 android13 rom 开发总纲说明 文章目录 1.前言2.问题分析3.代码分析4.代码修改5.编译6.彩蛋1.前言 有时候我们需要让固件里面内置好,相关的wifi的ssid和密码,让固件起来就可以连接wifi,不用在手动操作。 2.问题分析 这个功能,使用普通的安卓代码就可以实现了。 3.代…

C++ 复习记录(个人记录)

1、构造函数&#xff08;constructor&#xff09;是什么 答&#xff1a;类里面定义一个函数&#xff0c; 和类名一样&#xff0c; 这样在我们生成一个对象之后&#xff0c;就会默认调用这个函数&#xff0c;初始化这个类。 子类B继承父类A的情况&#xff0c; 当你调用子类的对…

Oasis 500M:开源的实时生成交互式视频内容的 AI 模型

❤️ 如果你也关注大模型与 AI 的发展现状&#xff0c;且对 AI 应用开发非常感兴趣&#xff0c;我会快速跟你分享最新的感兴趣的 AI 应用和热点信息&#xff0c;也会不定期分享自己的想法和开源实例&#xff0c;欢迎关注我哦&#xff01; &#x1f966; 微信公众号&#xff5c…

微服务实战系列之玩转Docker(十六)

导览 前言Q&#xff1a;基于容器云如何实现高可用的配置中心一、etcd入门1. 简介2. 特点 二、etcd实践1. 安装etcd镜像2. 创建etcd集群2.1 etcd-node12.2 etcd-node22.3 etcd-node3 3. 启动etcd集群 结语系列回顾 前言 Docker&#xff0c;一个宠儿&#xff0c;一个云原生领域的…

固定翼无人机飞行操控技术详解

固定翼无人机飞行操控技术是一个复杂而精密的领域&#xff0c;涵盖了从起飞准备到实际飞行操作&#xff0c;再到安全降落的各个环节。以下是对固定翼无人机飞行操控技术的详细解析&#xff1a; 一、起飞准备 1. 设备检查&#xff1a; 确保无人机充满电&#xff0c;检查电池状…

文件描述符fd 和 缓冲区

目录 1.文件描述符 fd 1.1文件打开的返回值fd&#xff08;重点&#xff09; 1.2.如何理解Linux下的一切皆文件 1.3.文件fd的分配原则 && 输出重定向 1.4.dup2()函数 2.缓冲区 2.1. 概念 2.2. 存在的原因 2.3. 类型(刷新方案) 2.4. 存放的位置 1.文件描述符 fd …

【qt qtcreator使用】【正点原子】嵌入式Qt5 C++开发视频

QT creator 的使用 一.qtcreator的介绍  (1).ui界面介绍    [1].软件左侧界面部分    [2].软件界面下方部分    [3].UI设计界面 (2).debug的使用 (3).项目的配置 (4).帮助文档的使用 (5).构建多个项目 二.qtcreator 的设置 (1).qt编译套件的设置 (2).设置快…

Vue3和Springboot前后端简单部署

一、Vue3Springboot 的前后端简单部署 (在win下面部署) 1、前端实现部署 思想: 前端打包项目后、放到nginx中进行部署 1、nginx 安装 和 解压 1、下载 nginx.zip win版本 解压就可以 2、解压后、启动程序 3、访问 nginx 欢迎页面 http://localhost/ 80 端口 可以省略 直接访…

【大数据学习 | kafka】kafka的ack和一致性

1. ack级别 上文中我们提到过kafka是存在确认应答机制的&#xff0c;也就是数据在发送到kafka的时候&#xff0c;kafka会回复一个确认信息&#xff0c;这个确认信息是存在等级的。 ack0 这个等级是最低的&#xff0c;这个级别中数据sender线程复制完毕数据默认kafka已经接收到…