vue2和vue3的按需引入的详细对比通俗易懂

以下是 Vue2 与 Vue3 按需引入的对比详解,用最简单的语言和场景说明差异:


一、按需引入的本质

  • 目标:只打包项目中实际用到的代码(组件、API),减少最终文件体积。
  • 类比:去餐厅点餐,只付你吃掉的菜,不用为整个菜单买单。

二、Vue2 的按需引入(手动模式)

1. 实现方式
  • 依赖工具:Babel 插件(如 babel-plugin-component)。
  • 核心原理:通过插件将代码“偷偷替换”为指定路径的组件文件。
2. 具体操作

以 Element UI 为例:

  1. 配置 Babel

    // babel.config.js
    plugins: [["component", { "libraryName": "element-ui",  // 库名"styleLibraryName": "theme-chalk"  // 样式路径}]
    ]
    
  2. 手动引入组件

    // src/plugins/element.js
    import Vue from 'vue';
    import { Button, Input } from 'element-ui';  
    Vue.use(Button);  // 必须逐个注册组件
    Vue.use(Input);
    
  3. 全局引入配置

    // main.js
    import './plugins/element';  // 手动引入所有用到的组件
    
3. 缺点
  • 手动维护列表:每新增一个组件,就要修改配置文件。
  • 样式需单独处理:要么手动引入 CSS,要么依赖插件自动添加。
  • 配置繁琐:对新手不友好,容易出错。

三、Vue3 的按需引入(自动模式)

1. 实现方式
  • 依赖工具:自动导入插件(如 unplugin-auto-import)。
  • 核心原理:工具自动扫描代码,动态生成组件导入语句。
2. 具体操作

以 Element Plus 为例:

  1. 配置 Vite

    // vite.config.js
    import AutoImport from 'unplugin-auto-import/vite';
    import Components from 'unplugin-vue-components/vite';
    import { ElementPlusResolver } from 'unplugin-vue-components/resolvers';export default {plugins: [AutoImport({ resolvers: [ElementPlusResolver()] }), // 自动导入 APIComponents({ resolvers: [ElementPlusResolver()] }), // 自动导入组件],
    };
    
  2. 直接使用组件

    <template><el-button>按钮</el-button>  <!-- 无需手动引入 -->
    </template>
    
3. 优点
  • 零配置:无需手动维护组件列表。
  • 自动处理样式:组件对应的 CSS 自动引入。
  • 开发体验好:写代码时无需关心导入语句。

四、为什么 Vue3 更高效?

1. 模块化设计
  • Vue3:每个 API 和组件都是独立模块(如 import { ref } from 'vue')。
  • Vue2:所有功能挂载在全局 Vue 对象(如 Vue.use()),难以拆分。
2. 原生 Tree-shaking 支持
  • Vue3:基于 ES Module,构建工具(如 Vite)可自动删除未使用代码。
  • Vue2:依赖 Babel 插件转换代码,无法彻底优化。
3. 现代工具链
  • 自动导入插件:动态分析代码,按需生成导入语句。
  • 示例
    <!-- 使用 <el-button> -->
    <!-- 插件自动生成: -->
    <script setup>
    import { ElButton } from 'element-plus';
    </script>
    

五、对比表格

特性Vue2Vue3
配置方式手动配置 Babel 插件一键配置自动导入插件
组件注册需手动调用 Vue.use()全自动
样式处理需手动引入或依赖插件自动关联
维护成本高(需手动更新组件列表)低(完全自动化)
适用场景中小型项目大型项目、追求极致的性能优化

六、总结

  • Vue2 按需引入:像手动拼装乐高,每个零件要自己找。
  • Vue3 按需引入:像全自动流水线,你要什么机器直接打包好。

Vue3 的改进让开发者更专注于业务逻辑,而非配置细节,同时大幅提升了项目的性能和可维护性。

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

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

相关文章

bash+crontab充当半个守护进程的歪招

两个cpolar下的不同程序&#xff0c;都需要定时监测&#xff0c;以免程序没有再运行。有点类似半个守护进程吧。但是守护进程不会写&#xff0c;咋搞&#xff1f;就用这个办法临时当下守门员。这里主要为了备忘xpgrep -各类参数的用法。 #!/bin/bashif pgrep -fl "check_…

Web自动化之Selenium 超详细教程(python)

Selenium是一个开源的基于WebDriver实现的自动化测试工具。WebDriver提供了一套完整的API来控制浏览器&#xff0c;模拟用户的各种操作&#xff0c;如点击、输入文本、获取页面元素等。通过Selenium&#xff0c;我们可以编写自动化脚本&#xff0c;实现网页的自动化测试、数据采…

如何调用 DeepSeek API:详细教程与示例

目录 一、准备工作 二、DeepSeek API 调用步骤 1. 选择 API 端点 2. 构建 API 请求 3. 发送请求并处理响应 三、Python 示例&#xff1a;调用 DeepSeek API 1. 安装依赖 2. 编写代码 3. 运行代码 四、常见问题及解决方法 1. API 调用返回 401 错误 2. API 调用返回…

基于flask+vue的租房信息可视化系统

✔️本项目利用 python 网络爬虫抓取某租房网站的租房信息&#xff0c;完成数据清洗和结构化&#xff0c;存储到数据库中&#xff0c;搭建web系统对各个市区的租金、房源信息进行展示&#xff0c;根据各种条件对租金进行预测。 1、数据概览 ​ 将爬取到的数据进行展示&#xff…

磐维数据库双中心容灾流复制集群搭建

1. 架构 磐维数据库PanWeiDB V2.0.0基于gs_sdr工具&#xff0c;在不借助额外存储介质的情况下实现跨Region的异地容灾。提供流式容灾搭建&#xff0c;容灾升主&#xff0c;计划内主备切换&#xff0c;容灾解除、容灾状态监控等功能。 2. 部署双中心磐维集群 2.1. 主集群 角色…

wordpress企业官网建站的常用功能

WordPress 是一个功能强大的内容管理系统(CMS)&#xff0c;广泛用于企业官网的建设。以下是企业官网建站中常用的 WordPress 功能&#xff1a; 1. 页面管理 自定义页面模板&#xff1a;企业官网通常需要多种页面布局&#xff0c;如首页、关于我们、产品展示、联系我们等。Wor…

Linux应用之构建命令行解释器(bash进程)

目录 1.分析 2.打印输入提示符 3.读取并且处理输入字符串 4.创建子进程并切换 5.bash内部指令 6.完整代码 1.分析 当我们登录服务器的时候&#xff0c;命令行解释器就会自动加载出来。接下来我们就。在命令行中输入指令来达到我们想要的目的。 我们在命令行上输入的…

ETL工具: Kettle入门(示例从oracle到oracle的数据导入)

kettle介绍 ETL工具,用于对数据的抽取&#xff08;Extract), 转换(Transform),加载 (Load&#xff09; Kettle 是一种ETL工具, 现称为 Pentaho Data Integration (PDI) 特点:纯JAVA语言编写 官方学习文档 网站: https://docs.hitachivantara.com/r/en-us/pentaho-data-int…

DeepSeek VS ChatGPT-速度、准确性和成本

撰写本文时马斯克刚刚发布了聊天机器人Grok2&#xff0c;10万张算卡体现了马斯克的财大气粗。近年来&#xff0c;人工智能模型取得了长足的发展&#xff0c;每个模型都力求在速度、准确性和成本效率方面超越其他模型。在本文中&#xff0c;我将深入研究比较中美在AI的焦点模型上…

SQLMesh 系列教程7- 详解 seed 模型

SQLMesh 是一个强大的数据建模和管道管理工具&#xff0c;允许用户通过 SQL 语句定义数据模型并进行版本控制。Seed 模型是 SQLMesh 中的一种特殊模型&#xff0c;主要用于初始化和填充基础数据集。它通常包含静态数据&#xff0c;如参考数据和配置数据&#xff0c;旨在为后续的…

基于大数据的国内高校排名可视化分析及推荐系统

【大数据】基于大数据的国内高校排名可视化分析及推荐系统&#xff08;完整系统源码开发笔记详细部署教程&#xff09;✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 高校排名一直是教育研究领域的重要课题&#xff0c;具有丰富的理论价值。通过分析和可…

【前端小点】vue3项目内根据主题读取不同文件夹下的图片资源(图片文件)

项目要求实现一键换肤的功能&#xff0c;不仅仅是主题颜色上的替换&#xff0c;还有图片素材的替换&#xff0c;主题颜色替换的方案大同小异&#xff0c;下面仅对图片素材的一件替换进行方法描述。 主要思路 使用本地仓库对当前主题进行存储&#xff0c;系统根据主题去加载不同…

recent移除task时,结束其所有进程和service(全Android版本)

目录 一、Launcher中forceStopPackage Android9 Android13 二、AMS中判断前台service也杀死 Android6 Android7 Android11 Android原生系统在清理后台应用时&#xff0c;其实并不能清理所有进程。例如&#xff1a; 在点击系统自带的播放器以后&#xff0c;播放音乐的时…

亲测可用,IDEA中使用满血版DeepSeek R1!支持深度思考!免费!免配置!

作者&#xff1a;程序员 Hollis 之前介绍过在IDEA中使用DeepSeek的方案&#xff0c;但是很多人表示还是用的不够爽&#xff0c;比如用CodeChat的方案&#xff0c;只支持V3版本&#xff0c;不支持带推理的R1。想要配置R1的话有特别的麻烦。 那么&#xff0c;今天&#xff0c;给…

Day6 25/2/19 WED

【一周刷爆LeetCode&#xff0c;算法大神左神&#xff08;左程云&#xff09;耗时100天打造算法与数据结构基础到高级全家桶教程&#xff0c;直击BTAJ等一线大厂必问算法面试题真题详解&#xff08;马士兵&#xff09;】https://www.bilibili.com/video/BV13g41157hK?p4&v…

centos服务器巡检脚本

服务器巡检脚本 系统负载shell脚本python将txt文件转换成excel&#xff0c;不正常巡检结果标记红色 系统负载shell脚本 #!/bin/bash#文件路径 path"/root/monitor.txt"#yum -y install bc sysstat net-tools lrzsz #获取主机名 system_hostname$(hostname | awk {pr…

大模型面经:SFT和RL如何影响模型的泛化或记忆能力?

监督微调 (SFT) 和强化学习 (RL)都是目前大模型的基础模型后训练技术&#xff0c;像DeepSeek-R1、kimi等的训练方法都将两种技术应用到了极致。 如何去设计训练步骤&#xff08;先SFT再RL&#xff0c;还是直接RL&#xff09;都需要对SFT和RL的能力有较深刻的了解。 本篇就以面…

Three.js 快速入门教程【一】开启你的 3D Web 开发之旅

系列文章目录 Three.js 快速入门教程【一】开启你的 3D Web 开发之旅 Three.js 快速入门教程【二】透视投影相机 Three.js 快速入门教程【三】渲染器 Three.js 快速入门教程【四】三维坐标系 Three.js 快速入门教程【五】动画渲染循环 Three.js 快速入门教程【六】相机控件 Or…

安全问答—安全的基本架构

前言 将一些安全相关的问答进行整理汇总和陈述&#xff0c;形成一些以问答呈现的东西&#xff0c;加入一些自己的理解&#xff0c;欢迎路过的各位大佬进行讨论和论述。很多内容都会从甲方的安全认知去进行阐述。 1.安全存在的目的&#xff1f; 为了支持组织的目标、使命和宗…

Navicat Premium17 连接Oracle出现 “未加载 Oracle库

报错信息如下 解决方案&#xff1a; 安装 Navicat for Oracle 12 for Mac 若已经打开任何来源&#xff0c;但运行还是遇到已损坏按照如下操作即可解决&#xff01; 终端中输入 xattr -cr cr 后面输入一个空格&#xff01;不要回车&#xff01;如下图 把 Navicat for Oracle…