老项目vue2.x误用了vue3的插件问题

news/2024/5/19 1:56:18/文章来源:https://blog.csdn.net/xy_peng/article/details/127221778

老项目vue2.x误用了vue3的插件问题

  • 背景
    • 插件
    • vue-template-compiler
    • vue-loader
    • 问题回溯
    • 总结

背景

vue3出来两年多了,它刚出来的时候,vue3相比vue2似乎并没有想像中那样受大家欢迎。因为两个版本的构架上相差太大了,许多的API都不兼容,其许多的争议到现在一直存在。在这里抛弃其其他的争议,仅就vue生态圈的插件升级问题,这一点确实坑到我了,很多的新项目或许还能接受vue3.0。但公司中的老项目的迁移工作量极大,仍需要继续维护vue2.X。

插件

针对项目迁移工作来说,许多的api需要自己手动实现转换,同时一些支持2.0插件在vue3中不能用了。例如on、on、onoff的api不能用了,在插件vue-template-compiler与vue-loader的版本上一不小心,也会踩到坑,以下主要说的是这两个插件。

vue-template-compiler

首先vue-template-compiler这个插件,在vue3.0之后有替代的插件**@vue/compiler-sfc**,Vue3也与这个插件琴瑟和鸣。在vue2中,原来的vue-template-compiler咋办呢?插件作者针对vue3的支持,也迟迟未更新,为了让用户丝滑的切换,尤大大亲自上手了,如下图,更新了vue-template-compiler插件的版本2.7.x,vue-template-compiler在2.6.14版本之前是支持vue2.x的,2.7开始之后加上了vue3的兼容

在这里插入图片描述
弄清楚以上插件版本更新后,发现的问题是老项目的package.json中安装的插件版本的锁定,默认使用^锁定大版本,次版本的版本用~ 如下:

    "vue-template-compiler": "~2.6.6","webpack": "^5.4.0",

在默认package-lock.json文件共享的情况下也没毛病,问题是一旦package-lock.json这个文件删除了,npm install 下会默认给升级了次版本,这就尴尬了,老项目直接报错了,报了vue3的错误

[@vue/compiler-sfc] ::v-deep usage as a combinator has been deprecated. Use :deep(<inner-selector>) instead.

在使用vue2项目中,vue-template-compiler插件最为适合的版本是2.6.14, vue3的语法编译就在2.7版本以上,以下是插件迭代的截图:
在这里插入图片描述

vue-loader

同样的是vue-loader, 老老实实用16+来区别也没毛病, 问题是最近这个插件推出了15.10.x-beta版本,同样会有以上问题,有时候还会莫名其妙的问题。所以在使用vue2项目中,vue-loader插件最为适合的版本是15.9.8, vue3的语法编译就在15.10.0以及版本以上,以下是插件迭代的截图:

在这里插入图片描述
以下是vue-loader插件的迭代图

在这里插入图片描述

问题回溯

发生的原因是删除了package-lock.json,破坏了项目原有依赖树的接口,需要重新安装依赖。 因为package.json中的插件使用的是^ , 锁定的是大版本,安装依赖时会默认拉取最新的次版本,更新了插件的版本。

总结

总结经验,牢记坑点:

1、共享package-lock.json文件, 不要去删除它

2、组件版本变更要留意,特别是核心插件大版本升级与小版本的升级

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

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

相关文章

洛谷题单 Part 2.4 分治

分治 即分而治之 将大问题化解为小问题逐一求解 这种题没有固定的模板 只有分治的思想 所以在做题的时候应当多想如何将一个大问题化解成若干个子问题进行求解 直接上题了 P1226 【模板】快速幂||取余运算 非常经典的分治问题 常规算法求aba^bab要O(b)O(b)O(b)的时间复杂度 我…

Mybatis常见查询总结,仅限于初级程序员阅读

情况描述&#xff1a; 本人初次接触Mybatis&#xff0c;然后对于其中的一些基础查询做一些简单总结&#xff0c;一次用来记录他的用法&#xff0c;便于以后查漏补缺。 1、Mybatis中查询特定的列:&#xff08;单列&#xff09; 如果查询指定列为Long类型&#xff0c;那么在re…

游戏合作伙伴专题:BreederDAO 与 Affyn一起重构现实生活

BreederDAO 团队很宣布与 Affyn 建立了新的合作关系&#xff0c;Affyn 是一家位于新加坡的公司&#xff0c;开发了基于地理位置的增强现实移动游戏。 移动元宇宙 Affyn 团队由来自 EA、任天堂、迪士尼和星巴克等顶级游戏、娱乐和生活方式公司的资深员工组成。他们洞悉了目前边玩…

html5网页设计作业代码 大学生校园网站制作 学校官网制作html

&#x1f329;️ 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f482; 作者主页: 【进入主页—&#x1f680;获取更多源码】 &#x1f393; web前端期末大作业&#xff1a; 【&#x1f4da;HTML5网页期末作业 (1000套…

性能大PK count(*)、count(1)和count(列)

最近的工作中&#xff0c;我听到组内两名研发同学在交流数据统计性能的时候&#xff0c;聊到了以下内容&#xff1a; 数据统计你怎么能用 count() 统计数据呢&#xff0c;count() 太慢了&#xff0c;要是把数据库搞垮了那不就完了么&#xff0c;赶紧改用 count(1)&#xff0c;这…

基于Gossip的online server

在游戏服务端架构中online server,有些也叫center server。 主要承载以下功能:存储玩家的在线信息,处理上线和下线消息。 转发消息给特定玩家。online server在架构图中的位置online server集群内部架构图,以3个实例为例:特点:svr之间相互连接,采用Gossip协议通信。 各s…

MCMS 审计之路

MCMS 是 J2EE 系统&#xff0c;完整开源的Java CMS&#xff0c;基于SpringBoot 2架构&#xff0c;前端基于vue、element ui。为开发者提供上百套免费模板,同时提供适用的插件&#xff08;文章、商城、微信、论坛、会员、评论、支付、积分、工作流、任务调度等...&#xff09;&a…

大学网课查题系统

大学网课查题系统 本平台优点&#xff1a; 多题库查题、独立后台、响应速度快、全网平台可查、功能最全&#xff01; 1.想要给自己的公众号获得查题接口&#xff0c;只需要两步&#xff01; 2.题库&#xff1a; 查题校园题库&#xff1a;查题校园题库后台&#xff08;点击跳…

VB6开发 用户控件OCX

VB6 中创建一个主窗体工程后,再添加一个 ActiveX用户控件工程 在用户控件窗体中可以添加 文本框和按钮的控件 属性Public strUrl As String方法发送消息 Public Sub WebSocketSendMsg(ByVal SendMsg As String) On Error GoTo ErrTrapDim sMsg As StringsMsg = msgInput.TextC…

公众号网课答案系统搭建

公众号网课答案系统搭建 本平台优点&#xff1a; 多题库查题、独立后台、响应速度快、全网平台可查、功能最全&#xff01; 1.想要给自己的公众号获得查题接口&#xff0c;只需要两步&#xff01; 2.题库&#xff1a; 查题校园题库&#xff1a;查题校园题库后台&#xff08;…

Java I/O流和反射机制

文章目录File类操作文件或目录属性认识Java的流使用字节流读写文本文件使用字节流类FileInputStream读文本文件使用字节流类FileOutputStream写文本文件使用字符流读写文本文件使用字符流类BufferedReader和FileReader读文本文件使用字符流类BufferedWrite和FileWrite写文本文件…

公众号订阅通知

洛塔服务号回复010获取代码。 功能说明 公众号订阅通知这个功能&#xff0c;微信本来打算替代掉模板消息和一次性订阅的&#xff0c;最后也没替代掉&#xff0c;成为单独的一个功能。 个人感觉和一次性订阅是没有太大区别的&#xff0c;只不过增加了一个长期订阅&#xff0c;…

2022测试工作太难找,怎样才能优先获得面试机会?

软件测试岗位前期门槛低&#xff0c;但是想要拿到高薪真没那么简单。工作 2-3 年薪资还在原地打转的同学&#xff0c;都大有人在。 根据我对招聘需求的研究&#xff0c;以及跟拿到高薪的同学交流发现&#xff0c;他们普遍被要求&#xff1a; 1、学历 在学历方面&#xff0c;…

SAP 顾问攻略笔记之寄售业务

寄售业务处理 供应商寄售&#xff08;Vendor Consignment&#xff09;是企业与供应商签订协议&#xff0c;要求供应商将货物送达企业仓库&#xff0c;由企业进行保管&#xff0c;并自由分配使用&#xff0c;此时不发生物权转移&#xff0c;企业实际消耗或者转为自有库存时&…

SQL抽象语法树及改写场景应用

1 背景 我们平时会写各种各样或简单或复杂的sql语句&#xff0c;提交后就会得到我们想要的结果集。比如sql语句&#xff0c;”select * from t_user where user_id > 10;”&#xff0c;意在从表t_user中筛选出user_id大于10的所有记录。你有没有想过从一条sql到一个结果集&…

Linux_Bash_Shell_索引数组和关联数组及稀疏数组

1. 索引数组一、什么是索引数组? 所谓索引数组就是普通数组,以整数作为数组元素的索引下标。二、实例。 备注: (a)使用-a选项定义索引数组,使用一对小括号()定义数组中的元素列表。 (b)索引数组使用整数作为数组元素下标。备注: (a)使用@和*作为数组下标,表示获取所有元素…

Abp项目(.net) 部署到服务端IIS 无法正常打开页面运行问题

1.当前项目使用abp开发&#xff0c;框架是.net6.0 版本。项目开发完毕后是按照正常流程发布。因此发布完成后根目录下面会有一个 .exe 后缀可执行的应用程序。 2. 如果直接点击.exe 应用程序&#xff0c;是能正常运行的输出。 3.但是部署到iis 上&#xff0c;就出现如下错误 …

2022华为杯D题问题一详细思路建模和程序

问题一思路 本问题的赛题总共包括两个子问题&#xff0c;需要同学们在满足上述数据依赖、控制依赖、以及各具体子问题的资源约束条件下进行资源排布&#xff0c;并充分考虑各子问题的优化目标&#xff0c;以求最大化芯片资源利用率。 问题1&#xff1a;给定资源约束条件如下&a…

远程桌面控制公司内网电脑修改PPT

微软的PowerPoint&#xff0c;相信是大家最熟悉的软件之一&#xff0c;其在我们工作中的重要性不言而喻。通常情况下&#xff0c;PPT做好后总会有各种各样的改动&#xff0c;如果恰逢自己没在办公室&#xff0c;而PPT又急需修改&#xff08;笔者就曾经碰到过这样尴尬的情况&…

Keras深度学习实战(29)——长短时记忆网络详解与实现

Keras深度学习实战&#xff08;29&#xff09;——长短时记忆网络详解与实现0. 前言1. RNN 的局限性2. LSTM 模型架构详解2.1 LSTM 架构2.2 LSTM 各组成部分与计算流程3. 从零开始实现 LSTM3.1 LSTM 模型实现3.2 验证输出小结系列链接0. 前言 长短时记忆网络 (Long Short Term…