vue3有了解过吗?和vue2的区别

news2025/1/14 17:59:06

vue3介绍

🍕🍕🍕关于vue3的重构背景,作者是这样说的:

  • 「Vue 新版本的理念成型于 2018 年末,当时 Vue 2 的代码库已经有两岁半了。比起通用软件的生命周期来这好像也没那么久,但在这段时期,前端世界已经今昔非比了。
  • 在我们更新(和重写)Vue 的主要版本时,主要考虑两点因素:首先是新的 JavaScript 语言特性在主流浏览器中的受支持水平(利用新的语言特性[es6]);其次是当前代码库中随时间推移而逐渐暴露出来的一些设计和架构问题」(解决架构暴露出来的问题)

哪些变化

  • 速度更快
  • 体积减少
  • 更易维护
  • 更接近原生
  • 更易使用(待验证)

速度更快

  • 重写了虚拟Dom实现
  • 对编译模板的优化
  • 组件初始化更高效
  • undate性能提高1.3-2倍
  • SSR速度提高了2-3倍

体积减少

🚜🚜🚜通过webpack的tree-shaking功能,可以将无用模块“剪辑”,仅打包需要的
两大好处:

  • 对开发人员,能够对vue实现更多其他的功能,而不必担忧整体体积过大
  • 对使用者,打包出来的包体积变小了

更易维护

🌮🌮🌮composition Api

  • 可与现有的Options API 一起使用
  • 逻辑组合和复用更灵活
  • vue3模块可以和其他框架搭配使用

更好的Typescript支持

🍕🍕🍕vue3是基于typescript编写的,可以享受到自动的类型定义提示

编译器重写

更接近原生

🥞🥞🥞可以自定义渲染API

更易使用

🧨🧨🧨响应式 Api暴露出来

import { observable,effect } from 'vue'
const state = observable({
	count:0
})
effect(()=>{
	console.log(`count is:${state.count}`)
})
state.count++

组件重新渲染识别

const Comp = {
	render(props){
		return h('div',props.count)
	},
	renderTriggered(e){
	  debugger 
	}
}

二、Vue3新增特性

🥟🥟🥟包括:

  • framents
  • Teleport
  • composition Api
  • createRenderer

framents

🍳🍳🍳 支持有多个根节点

<template>
	<header></header>
	<main v-bind="$attrs"></main>
	<footer></footer>
</template>

Teleport

🐱‍🏍🐱‍🏍🐱‍🏍是一种能够将我们的模板移动到DOMVue app之外的其他位置的技术,就有点像哆啦A梦的“任意门”
vue2 中,像modals,toast等这样的元素,如果我们嵌套在Vue的某个组件内部,那么处理嵌套组件的定位、z-index和样式就会变得很困难。
通过Teleport,我们可以在组件的逻辑位置写模板代码,然后在 Vue 应用范围之外渲染它

<button @click="showToast" class="btn">打开toast</button>
<teleport to="#teleport-target">
  <div v-if="visible" class="toast-wrap">
  	<div>Toast文案</div>
  </div>
</teleport>

createRenderer

🥫🥫🥫我们能够构建自定义渲染器,我们能够将vue的开发模型扩展到其他平台,我们可以将其生成在canvas画布上

composition Api

🍔🍔🍔通过这种形式,我们能够更加容易维护我们的代码,将相同功能的变量进行一个集中式的管理
在这里插入图片描述
简单使用

export default{
	setup(){
		const count = ref(0);
		const double = computed(()=>count.value*2)
		function increment(){
			count.value++ 
		} 
		onMounted(()=>console.log('component mounted!'))
		return{
			count,
			double,
			increment 
		}
	}
}

三、非兼容变更

🍖🍖🍖Global API

  • 全局Vue API已更改为使用应用程序实例
  • 全局和内部API已经被重构为可tree-shakable

模板指令

  • 组件上v-model 用法更改
  • 和非v-for节点上key用法已更改
  • 在同一元素上使用v-if和v-for优先级已更改
  • v-bind="object"现在排序敏感
  • v-for中的ref不再注册ref数组

组件

  • 只能使用普通函数创建功能组件
  • functional属性在单文件组件(SFC)
  • 异步组件现在需要defineAsncComponent方法来创建

渲染函数

  • 渲染函数API改变
  • s c o p e d S l o t s 属性已删除,所有插槽都通过 ‘ scopedSlots 属性已删除,所有插槽都通过` scopedSlots属性已删除,所有插槽都通过slots`作为函数暴露
  • 自定义指令 API 已更改为与组件生命周期一致
  • 一些转换class被重命名了
  • 组件 watch 选项和实例方法 $watch不再支持点分隔字符串路径,请改用计算函数作为参数
  • 在 Vue 2.x 中,应用根容器的 outerHTML 将替换为根组件模板 (如果根组件没有模板/渲染选项,则最终编译为模板)。VUE3.x 现在使用应用程序容器的 innerHTML。

其他小改变

  • beforeDestroy 生命周期选项被重命名为beforeUnmount
  • destroyed生命周期选项被重命名为unmounted
  • [prop default] 工厂函数不再有权访问 this是上下文
  • 自定义指令 API 已更改为与组件生命周期一致
  • data应始终声明为函数
  • 来自mixindata选项现在可简单地合并
  • attribute强制策略已更改

移除API

  • keyCode支持作为v-on的修饰符
  • $on,$off$once实例方法
  • 过滤filter
  • 内联模板attribute
  • $destroy实例方法。用户不应再手动管理单个Vue组件的生命周期。

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

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

相关文章

资源第一篇 =》bundle包

简介 bundle包主要用于游戏资源的模块化功能&#xff0c;以便更好的管理游戏资源、优化游戏资源的加载、优化游戏包体的大小&#xff0c;提高游戏体验。我们可以根据实际的场景&#xff0c;把游戏资源进行合理的分包。 bundle类型 cocos包分为内置bundle和自定义bundle。 内…

七、装饰器模式

装饰器模式&#xff08;Decorator Pattern&#xff09;是一种结构型设计模式&#xff0c;允许在不改变对象自身的情况下&#xff0c;动态地向对象添加新功能。它通过将功能附加到对象的方式来增强其行为&#xff0c;提供了一种灵活的替代方案来使用子类扩展功能。 主要组成部分…

python 检测端口是否开放

python的socket库可以检测端口是否开放。 import socket; sock socket.socket(socket.AF_INET, socket.SOCK_STREAM) result sock.connect_ex((127.0.0.1,80)) if result 0:print "Port is open" else:print "Port is not open" 这里sock.connect_ex()方…

机器人领域顶刊TRO最受欢迎的TOP 50文章盘点

介绍 众所周知&#xff0c;TRO是机器人领域的绝对顶刊&#xff0c;每一篇文章都是质量极高的。最近在看TRO官网的时候&#xff0c;发现官网给出了在TRO发布文章中最收欢迎的TOP 50 paper list。下面来看看都有哪些文章&#xff1f;是不是和您想的一样&#xff1f;下面文章的顺…

Ollama—87.4k star 的开源大模型服务框架!!

这一年来&#xff0c;AI 发展的越来越快&#xff0c;大模型使用的门槛也越来越低&#xff0c;每个人都可以在自己的本地运行大模型。今天再给大家介绍一个最厉害的开源大模型服务框架——ollama。 项目介绍 Ollama 是一个开源的大语言模型&#xff08;LLM&#xff09;服务工具…

【redis】认识redis和分布式系统

文章目录 认识 redisredis 的主要功能实现数据库实现缓存实现消息中间件 分布式系统单机架构为什么数据多了主机就难以应对 &#xff1f;分布式系统 认识 redis redis 的主要功能 用来在内存中存储数据 定义变量不就是在内存中存储数据吗&#xff1f;为什么还需要 redis 来向…

如何看待AI技术对人们生活的影响?

人工智能&#xff08;AI&#xff09;技术对人们生活的影响是多方面的&#xff0c;既有积极的一面&#xff0c;也存在一些需要关注的问题。以下是对AI技术在生活中影响的综合看法&#xff1a; 积极影响&#xff1a; 提高效率&#xff1a;AI技术在各行各业中的应用大大提高了工作…

14,子查询语句嵌套

1.1 查询研发部门的所有员工信息 #步骤1: 查询研发部门的 did SELECT did FROM t_department WHERE dname 研发部; #步骤2: 嵌套子查询,查询员工信息 SELECT * FROM t_employee WHERE did (SELECT did FROM t_department WHERE dname 研发部); 1.1 查询和白露性别和部门相…

Splashtop 在 Gartner Peer Insights™ 远程桌面软件客户之声评选中荣获“卓越表现者”称号

2024年9月4日 加利福尼亚州库比蒂诺 远程解决方案提供商 Splashtop 今天宣布&#xff0c;在最新发布的《2024年 Gartner Peer Insights™ 远程桌面软件客户之声》报告中&#xff0c;Splashtop 荣获“卓越表现者”称号。进入“卓越表现者”象限&#xff0c;意味着 Splashtop 的…

基于 Python 的 LIF 模型:探索神经元同步与小世界网络

在神经科学中&#xff0c;理解神经元之间的同步行为对解释大脑的功能非常重要。而泄漏积分发放&#xff08;Leaky Integrate-and-Fire, LIF&#xff09;模型作为一种经典的神经元模型&#xff0c;广泛应用于模拟神经元的膜电位变化以及脉冲发放。本篇博客将带你通过Python代码&…

大眼橙X7D Ultra和当贝D6X Pro选哪个好?三千价位,谁的性价比更高

在投影仪市场的激烈竞争中&#xff0c;3000多价位一款新产品问世&#xff0c;大眼橙X7D Ultra作为新款备受瞩目&#xff0c;与其对应的同价位佼佼者当贝D6X Pro都各自以其独特的优势吸引着消费者的目光。今天就来说说这款新品大眼橙X7D Ultra对比当贝D6X Pro有哪些不同之处&…

iOS 18beta/正式版升级办法分享

随着科技的飞速发展&#xff0c;苹果公司每一次的iOS系统更新都为我们带来了前所未有的便捷与惊喜。如今&#xff0c;iOS 18的发布再次激起了广大iPhone用户的升级热情。为了让大家能够顺利、高效地升级到这一全新系统&#xff0c;今天我将为大家分享几种实用的升级iOS 18的方法…

展会回顾 | SunTorque智能扭矩系统亮相GAF2024展览会,收获满满

9月&#xff0c;一个收获的季节&#xff0c; GAF 2024全球紧固—连接—装配技术大会暨展览会就在这样一个美好的季节中&#xff0c;在苏州花桥国际博览中心完美落幕。这场汇聚了全球顶尖技术与创新理念的盛会&#xff0c;不仅吸引了来自全国各地的制造商、科技巨头及行业精英&a…

电脑桌面整理怎么弄?分享8款桌面整理软件,轻松拿捏桌面美化!

电脑桌面是我们日常工作和学习中最常接触到的地方&#xff0c;但随着时间的推移&#xff0c;桌面上往往会堆积越来越多的文件和图标。这不仅让桌面看起来杂乱无章&#xff0c;也使得寻找特定文件变得困难&#xff0c;从而影响了工作和学习的效率。那么&#xff0c;如何有效整理…

Embedding模型提升效果的方法之二:SimCSE

0. 前言 SimCSE是通过对比学习的方式缓解预训练模型的各向异性问题&#xff0c;各向异性的产生原因在上一篇文章中已有介绍。SimCSE是2021年出的&#xff0c;后面出的 embedding 模型几乎都使用了对比学习来缓解预训练语言模型的各向异性问题。前面介绍的几篇文章无一例外使用…

1-2宿主环境

什么是宿主环境 指的是程序运行所必须的依赖环境。Android系统和ios系统是两个不同的宿主环境&#xff0c;安卓版的app是不能在ios系统上运行的。 小程序的宿主环境 &#x1f355;&#x1f355;&#x1f355; -手机微信是小程序的宿主环境 通信的主体 &#x1f354;&…

使用百度飞桨PaddleOCR进行OCR识别

1、代码及文档 代码&#xff1a;https://github.com/PaddlePaddle/PaddleOCR?tabreadme-ov-file 介绍文档&#xff1a;https://paddlepaddle.github.io/PaddleOCR/ppocr/overview.html 2、依赖安装 在使用过程中需要安装库&#xff0c;可以依据代码运行过程中的提示安装。…

高效实用的网站ICP备案查询接口

随着互联网的日益发展&#xff0c;对于网站的监管变得越来越重要。为了更好地管理和监督互联网上的网站&#xff0c;官方要求所有在中国境内的网站都需要进行ICP备案。因此&#xff0c;ICP备案不仅是法律要求&#xff0c;也是衡量一个网站是否正规的重要标志之一。为了便于开发…

开题报告撰写的四大难点与应对策略

AIPaperGPT&#xff0c;论文写作神器~ https://www.aipapergpt.com/ 对于每个即将进入毕业论文阶段的学生来说&#xff0c;开题报告是一道必经的门槛。开题报告不仅决定了你的论文方向&#xff0c;还对后续的研究和写作起到重要的引导作用。 然而&#xff0c;许多学生在撰写…

什么是车端、站端、电池端换电连接器?

材料选择与导电性能 换电连接器首先需要承受大电流、高电压的传输&#xff0c;因此其材料选择至关重要。为了确保电力传输的高效与稳定&#xff0c;大多数换电连接器采用高导电性材料&#xff0c;如铜材或更先进的合金材料。这些材料不仅具有优异的导电性能&#xff0c;还能在…