webpack与vite

本文介绍了Webpack的基本使用,包括初始化项目、配置打包规则(如CSS和图片处理)、集成Babel以支持新语法兼容,以及使用html-webpack-plugin生成HTML页面。同时,对比了Webpack与Vite的异同,强调Vite的ESM开发模式和快速打包特点。

webpack

  • 使用步骤:
    1. 初始化项目 pnpm init -y
    2. 安装依赖webpackwebpack-cli
    3. 在项目中创建src目录,然后编写代码(index.js
    4. 执行pnpm weboack来对代码进行打包(打包后观察dist文件夹)
  • 配置古文件(webpack.config.js)

const path = require("path")
module.exports = {
    mode: "production", // 设置打包的模式,production表示生产模式 development表示开发模式
    // entry: "./src/index.js", // 用来指定打包时的主文件,默认是./src/index.js
    output: { 
        // path: path.resolve(__dirname, 'dist'), // 指定的打包目录,必须绝对路径
        // filename: "main.js", // 打包后的文件名
        // clean: true, // 自动清理打包目录
    }, // 配置代码打包后的地址
    /*
        webpack默认情况下,只会处理js文件,如果我们希望它可以处理其他类型的文件,则需要引入loader
        
        - 以css为例:
            - 使用 css-loader可以处理js中的样式
            - 使用步骤:
                1. 安装:pnpm add css-loader -D
                2. 配置:
                module:{
                    rules: [
                        {
                            test: /\.css$/i,
                            use: "css-loader"
                        },
                    ]
                }
    */
    module:{
        rules: [
            { // css
                test: /\.css$/i,
                use: ["style-loader", "css-loader"]
            },
            { //图片
                test: /\.(png|svg|jpg|jpeg|gif)$/i,
                type: "asset/resource" //图片直接资源类型的数据,可以通过指定type来处理
            }
        ]
    }
}
  • 在编写js代码时,经常需要使用一些js中的新特性,而新特性在旧的浏览器中兼容性并不好。就导致我们无法使用一些新的特性。

  • 但是我们现在希望能够使用新的特性,我们可以采用一些折中的方案。依然使用新特性编写代码,但是代码编写完成时我们可以通过一些工具将新代码转换为旧代码。

  • babel就是这样一个工具,可以将新的js语法转换为旧的js,以提高代码的兼容性。

  • 我们如果希望在webpack支持babel,则需要向webpack中引入babel的loader

  • 使用步骤

      1. 安装 `npm install -D babel-loader @babel/core @babel/preset-env webpack`
      2. 配置:
    
module: {
  rules: [
    {
      test: /\.m?js$/,
      exclude: /(node_modules|bower_components)/,
      use: {
        loader: 'babel-loader',
        options: {
          presets: ['@babel/preset-env'],
        },
      },
    },
  ];
}
3. 在package.json中设置兼容列表
"browserslist": [
	"defaults"
]

  • 插件(plugin
    • 插件用来为webpack来扩展功能
    • html-webpack-plugin
      • 这个插件可以在打包代码后,自动在打包目录生成html页面
      • 使用步骤:
        1. 安装依赖 pnpm add -D html-webpack-plugin
        2. 使用:
// 引入html插件
const HTMLPlugin = require("html-webpack-plugin")
plugins: [
    new HTMLPlugin({
        // title: 'Hello Webpack' // html的title标题
        template: "./src/index.html"
    })
],
  • 配置源码的映射
devtool:"inline-source-map"

添加了以上代码之后,进入浏览器这里就能看见源代码,可在源代码上进入断点调试

在这里插入图片描述

Vite

  • Vite也是前端的构建工具

  • 相较于webpack,vite采用了不同的运行方式:

    • 开发时,并不对代码打包,而是直接采用ESM的方式来运行项目
    • 在项目部署时,在对项目进行打包
  • 除了速度外,vite使用起来也更加方便

  • 基本使用

    1. 安装vite

    2. vite的源码目录就是项目根目录

    3. 开发命令:

      vite 启动开发服务器

      vite build 打包

      vite preview 预览打包后代码

  • 使用命令创建

npm create vite@latest
yarn create vite
pnpm create vite
  • 配置文件: vite.config.js
  • 格式:
import { defineConfig } from 'vite'
import legacy from '@vitejs/plugin-legacy'

export default defineConfig({
    plugins: [
        legacy({
            targets: ["defaults", "ie 11"]
        })
    ]
})
WebpackVite 是现代前端开发中常用的构建工具,它们在核心机制、性能表现、配置灵活性以及适用场景等方面各有特点。 ### 构建模式核心机制 Webpack 采用打包器模式,在开发环境和生产环境均会对整个项目进行打包处理。冷启动时,Webpack 会遍历所有模块依赖并生成最终的 Bundle 文件。这一过程会消耗较多时间,尤其在大型项目中更为明显[^2]。 相比之下,Vite 利用浏览器原生支持的 ES Modules,在开发环境中跳过了打包过程,采用按需编译的方式。只有在浏览器请求某个模块时,Vite 才会实时编译该模块并返回结果。这种方式显著提升了开发服务器的启动速度和热更新效率[^2]。 ### 性能对比 在冷启动速度方面,Webpack 相对较慢,因为其需要全量扫描和打包依赖,而 Vite 仅需编译入口文件即可启动开发服务器,因此启动速度极快[^2]。 在热更新(HMR)方面,Webpack 的更新速度取决于 Bundle 的大小,而 Vite 的按需编译机制使其热更新速度达到毫秒级别,响应更加迅速[^2]。 在生产构建方面,Webpack 有着成熟的构建流程和优化机制,如 Tree Shaking、代码分割等,适合复杂的构建需求。而 Vite 在生产环境中使用 Rollup 进行打包,虽然构建速度快,但其生态相比 Webpack 略显薄弱[^3]。 ### 配置扩展性 Webpack 的配置较为复杂,需要手动处理 Loader 和 Plugin,但这也带来了更高的灵活性和定制化能力。它拥有庞大的插件生态,适用于各种复杂场景,如微前端架构等[^2]。 Vite 提供了开箱即用的体验,默认支持 TypeScript、CSS 预处理器等,简化了配置流程。虽然其插件生态还在快速增长中,但已经能够兼容部分 Rollup 插件,逐步完善中[^2]。 ### 适用场景 Webpack 更适合大型传统项目、需要兼容旧浏览器的项目以及需要复杂自定义构建流程的场景。对于追求极速开发体验的轻量项目,Vite 是更好的选择。Vite 特别适合现代浏览器项目(如使用 Vue/React 技术栈)或快速原型开发[^2]。 ### 总结选型建议 如果开发效率是首要考虑因素,尤其是新项目或基于现代框架(如 Vue 3 或 React)的项目,Vite 是理想的选择。而 Webpack 在需要深度定制构建流程或需要兼容旧系统的情况下更为合适。对于大型项目,也可以采用折中方案,即在开发环境中使用 Vite 提升效率,在生产环境中使用 Webpack 保证构建质量[^2]。 ```javascript // 示例:Vite 的简单配置文件 vite.config.js import { defineConfig } from 'vite'; import vue from '@vitejs/plugin-vue'; export default defineConfig({ plugins: [vue()], }); ``` ```javascript // 示例: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$/, loader: 'babel-loader', exclude: /node_modules/, }, ], }, }; ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值