构建工具-webpack和vite笔记

webpack

1. 使用步骤

  1. 初始化项目
npm init -y
  1. 安装依赖 webpack, webpack-cli
  • webpack: 核心依赖
  • webpack-cli: 命令行工具
npm i webpack webpack-cli -D
  1. 在项目中创建 src 目录,在 src 目录中创建 index.js 文件

webpack 默认会打包 src 目录下的 index.js 文件,后面可以通过 webpack.config.js 文件来修改默认的打包文件

  1. 构建 src/index.js 文件

打包后的文件会被打包到 dist 目录下

npx webpack
npx webpack --mode development # 指定开发环境
  • package.json 文件中添加 scripts 字段
"scripts": {"dev": "webpack","start": "webpack --mode development","build": "webpack --mode production"
}

2. 配置文件

  • webpack.config.js:默认的配置文件(是在 node 中运行的,使用 commonjs 规范)
module.exports = {// 配置打包模式:development 开发模式 production 生产模式mode: 'development' // 和上面目录效果一样
}

3. entry

打包的入口文件,可以是一个字符串,也可以是一个数组,也可以是一个对象

module.exports = {// 配置打包模式:development 开发模式 production 生产模式mode: 'development',// 配置入口文件(默认是src/index.js)// entry: './src/index.js',entry: {index: ['./src/index.js', './src/main.js']}// entry: {//    index: './src/index.js',//    main: './src/main.js'// },
}
  1. 字符串
{"entry": "./src/index.js"
}
  1. 数组

index.jsmain.js 多个文件打包到一个文件中

{index: ['./src/index.js', './src/main.js']
}
  1. 对象

每个文件对应一个入口文件,生成多个文件 dist/index.jsdist/main.js

{index: "./src/index.js",main: "./src/main.js",
}

4. output

  • path:打包后的文件路径
  • filename:打包后的文件名
  • clean:打包前清空打包目录
{output: {// 打包后的文件名// filename: '[name].js' // name 是占位符,会被 entry 中的 key 替换filename: '[name]-[hash].js', // hash 是占位符,会被一个随机的字符串替换// 打包后的文件路径path: path.resolve(__dirname, 'dist'),clean: true // 每次打包,自动清空打包目录}
}

5. loader

loader:用于对模块的源代码进行转换,可以将文件从不同的语言(如 JavaScriptCSSLESS)转换为 JavaScript 模块,以便在浏览器中使用

只要进行源代码进行转换的都是 loader

例如:在 index.js 文件中引入 css 文件

import './style/index.css'const h1 = document.createElement('h1')
h1.innerText = 'hello webpack'
document.body.appendChild(h1)console.log('hello webpack')

执行 npx webpack 命令后,会报错,因为 webpack 只能打包 JavaScript 文件,不能打包 css 文件

ERROR in ./src/style/index.css 1:3
Module parse failed: Unexpected token (1:3)
You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders
> h1 {
|     color: #369;
|     font-family: Arial, Helvetica, sans-serif;@ ./src/index.js 1:0-26

上面的报错信息告诉我们,需要一个合适的 loader 来处理这个文件类型,目前没有配置 loader 来处理这个文件类型

  • 解决步骤:
  1. 安装 css-loaderstyle-loader
# `css-loader`:将 `css` 文件转换为 `JavaScript` 模块
# `style-loader`:将 `css` 文件插入到 `head` 标签中
npm i css-loader style-loader -D
  1. webpack.config.js 文件中添加 loader

配置 loader 是通过 module.rules 数组来配置的

module.exports = {mode: 'development',entry: './src/index.js',output: {filename: 'index.js',path: path.resolve(__dirname, 'dist'),clean: true},// 配置 loadermodule: {rules: [{test: /\.css$/i, // 正则表达式,匹配.css 结尾的文件use: ['style-loader', 'css-loader'] // use 数组中的 loader 从右到左执行},{test: /\.(jpg|png|svg)$/i, // 图片类型文件,webpack默认支持,使用 type: asset/resource 类型的 loader 来处理type: 'asset/resource'}]}
}

⚠️ 注意:use 数组中的 loader 从右到左执行,先执行 css-loader,再执行 style-loader

总结:webpack 只能打包 JavaScript 文件,如果想要打包其他类型文件,需要添加对应文件的 loader

6. loader -> babel

babel:是一个 JavaScript 编译器,将 ES6 代码转换为 ES5 代码。可以将 JavaScript 新特性转换可以兼容的旧版本的 JavaScript 代码

  • 使用步骤:
  1. 安装 babel-loader@babel/core@babel/preset-env

babel-loader:将 babel 转换为 webpack 可以识别的 loader

@babel/corebabel 的核心库

@babel/preset-envbabel 的预设库,内置了一些常用的 babel 插件

npm i babel-loader @babel/core @babel/preset-env -D
  1. webpack.config.js 文件中添加 loader
{test: /\.m?js$/i,exclude: /node_modules/, // 排除 node_modules 目录下的文件use: {loader: 'babel-loader', // 使用的 loaderoptions: {presets: ['@babel/preset-env'] // 预设库}}
}
  1. package.json 设置兼容性
{"browserslist": {"production": [">0.2%", "not dead", "not op_mini all"],"development": ["last 1 chrome version","last 1 firefox version","last 1 safari version"]}// "browserslist": [//    "defaults" // 使用默认的浏览器列表// ]
}

7. plugin

plugin:用来扩展 webpack 的功能

7.1 html-webpack-plugin

作用:自动生成 html 文件,自动引入打包后的 js 文件

  • 使用步骤:
  1. 安装 html-webpack-plugin
npm i html-webpack-plugin -D
  1. webpack.config.js 文件中添加 plugin
const HtmlWebpackPlugin = require('html-webpack-plugin')module.exports = {mode: 'development',output: {clean: true},plugins: [// new HtmlWebpackPlugin(), // 自动生成 html 文件,自动引入打包后的 js 文件new HtmlWebpackPlugin({title: 'webpack app', // template的title会优先于这个titletemplate: './public/index.html' // 模板文件})]
}

8. devServer 开发服务器

devServer:是一个开发服务器,用于开发环境,它可以在内存中生成打包后的文件,不会在磁盘中生成打包后的文件,也不会在磁盘中生成 source-map 文件,它可以在浏览器中访问打包后的文件,也可以在浏览器中访问 source-map 文件

  • 使用步骤:
  1. 安装 webpack-dev-server
npm i webpack-dev-server -D
  1. 运行命令 webpack serve
npx webpack serve
npx webpack serve --open --port 8080 # 自动打开浏览器,端口号为8080

也可以在 webpack.config.js 文件中添加 devServer

{devServer: {port: 3000,open: true}
}

9. source-map

source-map:是一个映射文件,用于将打包后的文件映射到源代码文件,方便调试

  • 使用步骤:
  1. webpack.config.js 文件中添加 devtool
{devtool: 'inline-source-map'
}

vite

1. 简介

vite 是一个构建工具,相较于 webpackvite 采用了不同的运行方式:

  1. 开发时,并不对代码进行打包,而是直接采用 esm 模块的方式进行开发,这样可以提高开发效率

  2. 打包时,采用 rollup 进行打包,这样可以提高打包效率

  • 使用步骤:
  1. 安装 vite
npm i vite -D
  1. 根路径下创建 index.html 文件
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><metaname="viewport"content="width=device-width, initial-scale=1.0"/><title>vite</title></head><scriptdefertype="module"src="./index.js"></script><body></body>
</html>

需要使用模块化的方式引入 index.js 文件,否则会报错

vite 的源码目录就是根目录

  1. index.js 文件中引入 css 文件
import './style/index.css'const h1 = document.createElement('h1')
h1.innerText = 'hello webpack!!!'
document.body.appendChild(h1)console.log('hello webpack')
  1. 开发模式启动 vite
npx vite
  1. 命令

vite: 启动 vite 开发服务器

vite build: 打包 vite 项目

vite preview: 预览 vite 打包后的代码

2. 配置文件

vite.config.js:默认的配置文件,使用 esm 规范

  • 使用步骤:
  1. 安装 @vitejs/plugin-legacy

用于兼容低版本的浏览器

npm i @vitejs/plugin-legacy -D
# 使用vite build时,需要安装terser,用于压缩代码,否则会报错
npm i terser -D
  1. 在根路径下创建 vite.config.js 文件
import { defineConfig } from 'vite'
import legacy from '@vitejs/plugin-legacy'export default defineConfig({plugins: [legacy({targets: ['defaults', 'IE 11']})]
})

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

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

相关文章

FFmpeg 4.3 音视频-多路H265监控录放C++开发十. 多线程控制帧率。循环播放,QT connect 细节,

在前面&#xff0c;我们总结一下前面的代码。 在 FactoryModeForAVFrameShowSDL 构造函数中 init SDL。 通过 QT timerevent机制&#xff0c;通过startTimer(10);每隔10ms&#xff0c;就会调用timerEvent事件。 在timerEvent事件中&#xff0c;真正的去 读取数据&#xff0c…

企业文件加密要怎么做?好用的10款企业文件加密软件排行榜!

在现代信息化的工作环境中&#xff0c;企业数据安全面临着越来越多的威胁。尤其是当涉及到敏感文件和商业机密时&#xff0c;如何保护这些数据不被泄露或遭受恶意攻击显得尤为重要。企业文件加密成为了保护企业信息安全的关键手段。本文将探讨如何进行企业文件加密&#xff0c;…

20241107给野火LubanCat1-BTB刷Ubuntu的预编译固件并点亮USB接口的热像仪AT600

20241107给野火LubanCat1-BTB刷Ubuntu的预编译固件并点亮USB接口的热像仪AT600 2024/11/7 20:08 缘起&#xff1a;需要使用RK3566的linux/Buildroot系统。 将 鲁班猫的 云盘资料下载之后&#xff0c;发现里面没有Buildroot的预编译固件。 火速联系 淘宝客服&#xff01;转技术支…

VMware没有卸载干净,安装后ping不通

目录 1.问题 2.问题分析 3. 解决办法 &#x1f353; STEP1&#xff1a;卸载VMware &#x1f348; STEP2&#xff1a;services.msc设置 &#x1f352;STEP3&#xff1a;安装everything删除所有与vmware相关的文件 &#x1f351;STEP4&#xff1a;使用CCleaner清理修复注册…

【科普】简述机器学习和深度学习及其相关的算法

文章目录 机器学习1. 基本概念2. 机器学习的分类3. 机器学习的常用方法4. 应用领域5. 挑战与未来6. 未来趋势 机器学习算法 深度学习1.深度学习的基本概念2.深度学习的主要架构3.深度学习的应用4.深度学习的挑战 深度学习算法 机器学习 机器学习是人工智能的一个重要分支&…

HCIP--3实验- 链路聚合,VLAN间通讯,Super VLAN,MSTP,VRRPip配置,静态路由,环回,缺省,空接口,NAT

学习目标&#xff1a; 链路聚合VLAN间通讯Super VLANMSTPVRRPip配置,静态路由,环回&#xff0c;缺省&#xff0c;空接口NAT 学习内容&#xff1a; 实验拓扑实验需求实验需求分析实验配置内容 &#xff08;每一个设备的每一步操作&#xff09;实验结果验证 1.实验拓扑 搭建 …

Zabbix监控架构

目录 1. Zabbix监控架构-CS架构 2. Zabbix极速上手指南 主机规划 2.1 部署ngxphp环境并测试 检查安装结果 2.2 部署数据库 2.3 编译安装zabbix-server服务端及后续配置 2.4 部署前端代码代码进行访问 前端的配置文件(连接数据库与主机名等信息) 2.5 欢迎来到zabbix 2…

【CentOS】中的Firewalld:全面介绍与实战应用(上)

&#x1f407;明明跟你说过&#xff1a;个人主页 &#x1f3c5;个人专栏&#xff1a;《Linux &#xff1a;从菜鸟到飞鸟的逆袭》&#x1f3c5; &#x1f516;行路有良友&#xff0c;便是天堂&#x1f516; 目录 一、引言 1、iptables 时代 2、firewalld 时代 3、 从 ipt…

人工智能未来前景好不好?

人工智能&#xff08;AI&#xff09;正以前所未有的速度改变着我们的世界。随着技术的不断进步&#xff0c;AI不仅在各行各业中扮演着越来越重要的角色&#xff0c;也为求职者和职业发展带来了广阔的机会。那么&#xff0c;人工智能未来的前景如何&#xff1f; 1 高增长行业 人…

湘潭大学软件工程专业选修 SOA 期末考试复习(二)

文章目录 回顾序言第一章课后题填空选择简答 第二章课后题填空选择编程 计划第三章课后题填空选择简答编程 第四章课后题填空选择简答编程 第五章课后题填空选择简答编程 第六章课后题说明 第七章课后题填空选择简答编程 第八章课后题填空选择简答编程 第九章课后题填空选择简答…

JVM垃圾回收详解

前言 当需要排查各种内存溢出问题、当垃圾收集成为系统达到更高并发的瓶颈时&#xff0c;我们就需要对这些“自动化”的技术实施必要的监控和调节。 堆空间的基本结构 Java 的自动内存管理主要是针对对象内存的回收和对象内存的分配。同时&#xff0c;Java 自动内存管理最核…

Hive 操作基础(进阶篇✌️)

Hive 进阶操作 分区表 创建分区表 create table score_part(字段名 字段类型,字段名 字段类型 )partitioned by (分区字段 分区类型) row format delimited fields terminated by \t; 创建单极分区表 注意: 分区的列名不能和数据列名相同.分区列会当做虚拟列出现在数据列…

【Kafka】Windows+KRaft部署指南

【Kafka】WindowsKRaft部署指南 摘要本地环境说明官网快速开始修改config/kraft/server.properties初始化数据存储目录启动 测试创建topic创建生产者创建消费者 FAQ输入行太长。命令语法不正确。问题描述解决方案 参考资料 摘要 Kafka是一种高吞吐量的分布式发布订阅消息系统&…

Docker-软件容器平台

一、容器 1、什么是容器 容器就是将软件打包成标准化单元&#xff0c;以用于开发、交付和部署 容器镜像是轻量的、可执行的独立软件包 &#xff0c;包含软件运行所需的所有内容&#xff1a;代码、运行时环境、系统工具、系统库和设置。容器化软件适用于基于 Linux 和 Windows…

OSS和FastDFS的区别

FastDFS&#xff1a; FastDFS 是一种开源的轻量级分布式文件系统&#xff0c;基于HTTP协议实现。具有高扩展性、高可用性和高稳定性。它解决了大容量文件存储和高效访问的问题&#xff0c;适合作为大容量文件的存储服务器。FastDFS 通过文件系统集群&#xff0c;使得用户可以将…

分离编译(介绍,解决“类模板定义和声明不在同一文件导致链接错误“的问题),类模板实例化原理,

目录 分离编译 介绍 问题代码示例 代码 说明 预处理 编译 链接 类模板实例化原理 总结 解决方法 显式实例化 模板的声明和定义放在一个头文件 分离编译 介绍 分离编译是一种编程技术 允许将程序代码分割成多个文件&#xff0c;每个文件可以独立地编译成目标文件…

云计算答案

情境一习题练习 一、选择题 1、在虚拟机VMware软件中实现联网过程&#xff0c;图中箭头所指的网络连接方式与下列哪个相关&#xff08; C &#xff09;。 A.仅主机模式 B.桥接 C.NAT D.嫁接 2、请问下图这个虚拟化架构属于什么类型&#xff08; A …

如何做好多项目进度管理

在同时管理多个项目时&#xff0c;重要的是要确保每个项目都能按时、按质完成。有效的时间管理、资源优化配置、持续的沟通和使用专业工具是关键要素。这些元素有助于维护项目的整体质量和效率&#xff0c;确保所有项目成员的责任和期望都明确无误。本文将深入探讨如何通过实践…

如何在vscode中安装git详细新手教程

一、安装git后点击vscode中的设置 今天教大家如何在VScode中编写代码后提交到git仓库&#xff0c;如果我们不想切换到git的命令行窗口&#xff0c;可以在VScode中配置git&#xff0c;然后就可以很方便快捷的把代码提交到仓库中。 二、在输入框中输入 git.path &#xff0c;再点…

使用Docker Compose构建多容器应用

&#x1f493; 博客主页&#xff1a;瑕疵的CSDN主页 &#x1f4dd; Gitee主页&#xff1a;瑕疵的gitee主页 ⏩ 文章专栏&#xff1a;《热点资讯》 使用Docker Compose构建多容器应用 引言 Docker Compose 简介 安装 Docker Compose 创建基本配置 运行多容器应用 查看服务状态 …