浅谈webpack

目录

什么是webpack?


什么是webpack?

将模块化代码打包生成普通脚本文件 应用在浏览器中

本质上,webpack 是一个用于现代 JavaScript 应用程序的 静态模块打包工具 。当 webpack 处理应用程序时,它会在内部从一个或多个入口点构建一个 依赖图(dependency graph),然后将你项目中所需的每一个模块组合成一个或多个 bundles,它们均为静态资源,用于展示你的内容。

webpack官网:webpack | webpack 中文文档 | webpack 中文网 (webpackjs.com)

先创建一个文件夹,在集成终端运行npm init -y命令初始化项目,再运行

cnpm i webpack webpack-cli --save-dev

安装webpack

创建a.js、b.js、main.js

创建webpack.config.js

复制代码
const path =  require('path');
module.exports = {
  // 核心
  // 入口
  entry:'./main.js',
  // 输出
  output:{
    path:path.resolve(__dirname,'dist'),
    filename:'bundle.js',
    clean:true
  },
}

打开package.json在此处添加打包命令

在集成终端执行npm run build 打包命令,生成一个dist目录

在此目录下创建一个html文件,在<script></script>标签中引入这个bundle.js文件

打开网页

这样,模块化js代码就能作用于浏览器上了。

每次使用npm run build命令总需要我们手动去创建html文件并且手动引入,很繁琐

我们可以在webpack.config.js中引入插件即可自动生成html文件并且引入js文件。

首先安装该插件

复制代码
cnpm i html-webpack-plugin --save-dev

const path = require('path')
// 引入插件
const htmlWebpackPlugin = require('html-webpack-plugin');
module.exports = {
  // 核心
  entry: './src/main.js',
  output: {
    path:path.resolve(__dirname,'dist'),
    filename:'bundle.js',
    clean: true
  },
  plugins: [new htmlWebpackPlugin()]
}

这样我们build的时候就会自动生成html文件并且引入js了。

我们再引入一个可视化插件

安装插件

复制代码
cnpm i webpack-handle-analyzer --save-dev

const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
plugins: [new htmlWebpackPlugin(),new BundleAnalyzerPlugin()],

在这里我们可以清晰的看到各个模块,可以判断是否误引入模块依赖,或者模块依赖过大。

当我们入口有多个的话,通过可视化模块可以发现分模块化会优化性能。

复制代码
  entry: {
    home:'./src/home.js',
    main:'./src/main.js'
  },

我们可以将这些分模块的公共部分抽离出来进一步优化性能,使用splitChunks

复制代码
module.exports = {
  // 入口
  entry: {
    home:'./src/home.js',
    main:'./src/main.js'
  },
  output: {
    path:path.resolve(__dirname,'dist'),
    filename:'bundle_[name].js'
  },
  plugins: [new BundleAnalyzerPlugin()],
  optimization: {

    splitChunks: {

      chunks: 'all',

    },

  },
}

我们这样可以引入模块化js文件,webpack只能解释js,无法解释非js文件,那么css、sass或less该如何引入呢?

将模块化css和scss转换为普通css

在集成终端安装css加载器,

复制代码
cnpm i style-loader css-loader --save-dev

sass

复制代码
cnpm i sass -S

在webpack.config.js这样写

这样,模块化css和sass就能作用于html文件了

相关推荐
Wect4 分钟前
深度剖析浏览器跨域问题
前端·面试·浏览器
陈随易18 分钟前
bun将会支持Bun.image,你怎么看?
前端·后端·程序员
jingqingdai335 分钟前
别用正则格式化 HTML!我用 DOM 遍历实现零风险本地格式化,老项目重构效率直接拉满
前端·重构·html
木斯佳38 分钟前
前端八股文面经大全:腾讯前端实习二、三OC面(2026-04-27)·面经深度解析
前端·状态模式
Python私教1 小时前
如意Agent日志系统重构:从 print() 大海捞针到结构化可观测性栈
java·前端·重构
We་ct1 小时前
LeetCode 97. 交错字符串:动态规划详解
前端·算法·leetcode·typescript·动态规划
Chengbei111 小时前
轻量化 Web 安全日志分析神器 星川智盾日志威胁检测、地理溯源、MITRE ATT&CK 映射,支持 Windows/macOS/Linux
前端·人工智能·安全·web安全·macos·系统安全·安全架构
风流 少年1 小时前
Python Web框架:FastAPI
前端·python·fastapi
GISer_Jing1 小时前
AI时代面试新常态——从“会用工具”到“深挖原理”的跨越
前端·人工智能·ai编程