IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> webpack5 学习(七)—— 管理输出 -> 正文阅读

[JavaScript知识库]webpack5 学习(七)—— 管理输出

项目结构:

  webpack-demo
  |- package.json
  |- package-lock.json
  |- webpack.config.js
  |- /dist
    |- bundle.js
    |- index.html
  |- /src
    |- index.js
  |- /node_modules

修改webpack.config.js

const path = require('path')

module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'bundle.js',
    path: path.resolve(__dirname, 'dist')
  }
}

src/index.js

import _ from 'lodash';

function component () {
  const element = document.createElement('div');

  // lodash 在当前 script 中使用 import 引入
  element.innerHTML = _.join(['Hello', 'webpack'], ' ');

  return element;
}

document.body.appendChild(component());

移除之前安装的依赖:

npm uninstall css-loader csv-loader json5 style-loader toml xml-loader yamljs

移除完成:
在这里插入图片描述

准备工作

print.js

新建文件 src/print.js

src/print.js

export default function printFunx () {
  console.log('This is print.js~');
}

项目结构:

  webpack-demo
  |- package.json
  |- package-lock.json
  |- webpack.config.js
  |- /dist
  |- /src
    |- index.js
    |- print.js
  |- /node_modules

src/index.js

修改 src/index.js

import _ from 'lodash';
import printFunx from './print.js'

function component () {
  const element = document.createElement('div');
  const btn = document.createElement('button')

  // lodash 在当前 script 中使用 import 引入
  element.innerHTML = _.join(['Hello', 'webpack'], ' ');
  btn.innerHTML = 'Let click it!'
  btn.onclick = printFunx

  element.appendChild(btn)

  return element;
}

document.body.appendChild(component());

dist/index.html

更新 dist/index.html 文件,为 webpack 分离入口做好准备:

<!DOCTYPE html>
<html>

<head>
  <meta charset="UTF-8">
  <title>webpack demo - 管理输出</title>
  <script src="./print.bundle.js"></script>
</head>

<body>
  <script src="./index.bundle.js"></script>
</body>

</html>

调整了配置,将在 entry 添加 src/print.js 作为新的入口起点(print)。

webpack.config.js

修改 output,以便根据入口起点定义的名称,动态地产生 bundle 名称:

const path = require('path')

module.exports = {
  entry: {
    index: './src/index.js',
    print: './src/print.js',
  },
  output: {
    filename: '[name].bundle.js',
    path: path.resolve(__dirname, 'dist')
  }
}

执行 npm run build

在这里插入图片描述

可以看到,webpack 生成 print.bundle.jsindex.bundle.js 文件,这和在 index.html 文件中指定的文件名称相对应。

在浏览器中打开 index.html,点击按钮,打印出了信息:

在这里插入图片描述

但是,如果更改了一个入口起点的名称,甚至添加了一个新的入口,会在构建时重新命名生成的 bundle,但是 index.html 文件仍然引用旧的名称。

接下来,用 HtmlWebpackPlugin来解决这个问题。

设置 HtmlWebpackPlugin

安装插件

首先,安装插件:

npm install --save-dev html-webpack-plugin

安装完成:
在这里插入图片描述

webpack.config.js

并且调整 webpack.config.js 文件:

const path = require('path')
const HtmlWebpackPlugin = require('html-webpack-plugin');

module.exports = {
  entry: {
    index: './src/index.js',
    print: './src/print.js',
  },
  plugins: [
    new HtmlWebpackPlugin({
      title: '管理输出',
    }),
  ],
  output: {
    filename: '[name].bundle.js',
    path: path.resolve(__dirname, 'dist')
  }
}

执行 npm run build
在这里插入图片描述

虽然在 dist/ 文件夹已经有了一个 index.html 这个文件,但是 HtmlWebpackPlugin 还是会默认生成它自己的 index.html 文件。

也就是说,用新生成的 index.html 文件,替换了原有的文件。

在代码编辑器中打开 index.html:

<!doctype html><html><head><meta charset="utf-8"><title>管理输出</title><meta name="viewport" content="width=device-width,initial-scale=1"><script defer="defer" src="index.bundle.js"></script><script defer="defer" src="print.bundle.js"></script></head><body></body></html>

可以看到, HtmlWebpackPlugin 创建了一个全新的文件,所有的 bundle 会自动添加到 html 中。

清理 /dist 文件夹

webpack 生成文件,并放置在 /dist 文件夹中,但是它不会追踪哪些文件是实际在项目中用到的。

由于遗留了之前的指南和代码示例, /dist 文件夹显得相当杂乱。

推荐做法:在每次构建前清理 /dist 文件夹,这样只会生成用到的文件。

现在,使用 output.clean配置项实现这个需求。

webpack.config.js

修改webpack.config.js

const path = require('path')
const HtmlWebpackPlugin = require('html-webpack-plugin');

module.exports = {
  entry: {
    index: './src/index.js',
    print: './src/print.js',
  },
  plugins: [
    new HtmlWebpackPlugin({
      title: '管理输出',
    }),
  ],
  output: {
    filename: '[name].bundle.js',
    path: path.resolve(__dirname, 'dist'),
    clean: true
  }
}

执行 npm run build
在这里插入图片描述

检查 /dist 文件夹,现在,只能看到构建后生成的文件,而没有了旧文件。

manifest

webpack 通过 manifest,可以追踪所有模块到输出 bundle 之间的映射。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-03 16:03:16  更:2022-03-03 16:04:16 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 10:46:31-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码