赞
踩
Tree-shaking 是指在打包过程中通过静态分析,识别并删除未使用的代码,以减小最终输出文件的大小。
不同点 | vite | webpacke |
---|---|---|
插件生态 | 相对较少 | 非常丰富 |
配置复杂度 | 在设计上更注重开箱即用,大部分场景下用户无需自己写配置文件 | 配置相对复杂,对新手不够友好 |
开发模式 | 采用了基于ES Module的开发服务器,只有在需要时才会编译对应的模块,大幅度提升了开发环境的响应速度。 | 在开发模式下依然会对所有模块进行打包操作,虽然提供了热更新,但大型项目中依然可能会出现启动和编译缓慢的问题; |
打包效率 | 利用了浏览器对ES Module的原生支持,只打包和缓存实际改动的模块,从而极大提高了打包效率 | 会把所有的模块打包成一个bundle,这会导致初次加载速度较慢 |
热更新机制 | 热更新是增量更新,只更新修改的文件,所以即使在大型应用中也能保持极快的编译速度 | 热更新是全量更新,即使修改一个小文件,也会重新编译整个应用,这在大型应用中可能会导致编译速度变慢 |
应用场景 | 凭借其轻量和速度,更适合于中小型项目和快速原型开发 | 其丰富的功能和扩展性,适合于大型、复杂的项目 |
vite是一个由Vue.js开发的构建工具,它利用了ES Module Imports,在开发环境下可以实现按需编译,加快了开发速度。而在生产环境下,它使用Rollup进行打包,提供更好的tree-shaking、代码压缩和性能优化。
vite主要解决了现有工具(如webpack、rollup)在大型项目开发过程中存在的启动慢、热更新慢等问题。vite致力于为现代前端工作流提供一个更快、更轻的解决方案。
Vite的特点包括:
// vite.config.js import { defineConfig } from 'vite' import vue from '@vitejs/plugin-vue'; // 导入 Vue 插件 export default defineConfig({ // 项目根目录,默认为当前工作目录 root: './', // 指定构建的目标目录,默认为 "dist" build: { outDir: 'dist', }, // 项目的基础公共路径,默认为 "/" base: '/', // 指定静态资源目录,默认为 "public" publicDir: 'public', // 配置插件,可以在这里添加 Vite 插件 plugins: [ vue(), // 添加 Vue 插件 ], // 配置解析选项,例如别名等 resolve: { alias: { '@': '/src', // 设置 @ 别名指向 src 目录 }, }, // 配置开发服务器 server: { port: 3000, // 指定开发服务器端口,默认为 3000 open: true, // 启动开发服务器时自动打开浏览器 proxy: { // 代理 '/api': { target: 'http://11.11.11.11:9900/', changeOrigin: true, rewrite: path => path.replace(/^\/api/, '') }, } }, // 配置优化选项,例如按需加载依赖项等 optimizeDeps: { // 可以配置优化依赖项的行为 }, });
webpack 是一个用于现代 JavaScript 应用程序的 静态模块打包工具。当 webpack 处理应用程序时,它会在内部从一个或多个入口点构建一个 依赖图(dependency graph),然后将你项目中所需的每一个模块组合成一个或多个 bundles,它们均为静态资源,用于展示你的内容。
// vue.config.js const path = require('path'); const HtmlWebpackPlugin = require('html-webpack-plugin'); const { VueLoaderPlugin } = require('vue-loader'); module.exports = { // 入口文件 entry: './src/main.js', output: { // 输出路径 __dirname是nodejs的变量,代表当前文件webpack.js目录的绝对路径 path: path.resolve(__dirname, 'dist'), // 输出文件名 filename: 'bundle.js', publicPath: '/', }, resolve: { // 用于指定在引入模块时可以省略的文件扩展名,可以让你在引入文件时不需要写明文件的扩展名 extensions: ['.js', '.vue'], // 用于创建模块路径的别名,可以简化模块引入的路径,可以让你使用 @ 来代替 src 目录的绝对路径。 alias: { '@': path.resolve(__dirname, 'src'), }, }, module: { rules: [ { test: /\.vue$/, loader: 'vue-loader', }, { test: /\.js$/, exclude: /node_modules/, use: { loader: 'babel-loader', }, }, { // test:使用正则匹配文件 // 这个规则表示当 Webpack 遇到以 .css 结尾的文件时,会先使用 css-loader 处理,然后再使用 style-loader 将样式注入到页面中。 test: /\.css$/, use: ['style-loader', 'css-loader'], }, { test: /\.(png|jpe?g|gif)$/i, use: [ { loader: 'file-loader', options: { name: '[name].[ext]', outputPath: 'images', }, }, ], }, ], }, plugins: [ // html-webpack-plugin插件会打包html文件 // 功能:会默认创建一个空的html,自动引入打包后输出的所有资源(js/css) new HtmlWebpackPlugin({ template: './public/index.html', filename: 'index.html', favicon: './public/favicon.ico', }), // VueLoaderPlugin这个插件是 Vue Loader 的一个插件,用于解析和转换 Vue 单文件组件。 new VueLoaderPlugin(), ], devServer: { // 指定服务器的根目录,告诉服务器从哪里提供内容 contentBase: path.join(__dirname, 'dist'), compress: true, // 指定开发服务器的端口号,默认为 8080。 port: 9000, open: true, // 设置代理,用于解决跨域请求问题。可以将某些 URL 下的请求代理到另外一个服务器。 proxy: { '/api': { target: 'http://11.11.11.11:9900/', changeOrigin: true, ws: true, pathRewrite: { '': '', }, }, }, }, devtool: 'eval-source-map', // 模式 用于指定当前构建的模式。它有三个可选值:development、production 和 none。 mode: 'development' };
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。