vue3.0的变化汇总

news2024/11/19 21:22:50

vue2迁移vue3 文档 https://www.javascriptc.com/vue3js/guide/migration/render-function-api.html
1.创建项目

npm init vite-app
cd
npm install
npm run dev

2.setUp()

  • 组合api的(解决v2业务逻辑分散的问题)方法可以单独写在外面的js。
    -本质:注入api 注入到option api中去

setup代替beforeCreated 和 created(在他们之间执行) 其他得周期前面加on,当然也是兼容之前vue2得生命周期得
注意 这里没是不能使用 data methods 也支持async await

setup() {
let {conut,changeCount}=AAA();
    return {
     	conut,changeCount
    }
  },
function AAA(){
    // 定义一个变量  ref包裹 才能自动更新
    // ref只能监听简单类型得变化,数组对象不行(reactive)
    let conut = ref(0);
    function changeCount(){
      console.log(conut);
      // 值取value
      conut.value+=1
    }

    return {
      conut,
      changeCount
    }
}
  • ref 和reactive 支持响应式变化

ref如何ref(obj.name)将对象得某一个字段设置成响应试,改变后不影响原数据
toRef(obj,"name)

  • 递归监听 和 非递归监听

递归监听:ref和 reactive都是支持的,但是数据量比较大的时候非常耗性能(其实是将每层都包装成来一个proxy对象)
非递归监听:只会监听第一层得变化,(数据量比较大得时候使用)
使用shallowReactive代替ef和 reactive
shallowRef创建得数据 监听得是.value得变化
triggerRef 使用 triggerRef(state) 手动得去更新,只适用于shallowRef

  • toRow(xxxx) 得到reactive 或者 ref得一个原始数据

注意:
let obj={name:“11”}
let newObj=reactive(obj);
let obj1=toRow(newObj);
obj 和 obj1是一样得 修改之后是不会更新页面得, 更新页面 必须是修改newObj

如果是ref
let obj1=toRow(newObj).value;

  • markRaw(obj) 使用后数据不会被追踪 不能实时更新
  • toRef

ref :复制,修改响应式数据,不会影响以前得数据,会自动更新页面
toRef:引用,修改会影响以前得数据,不会自动更新页面

3.defineAsyncComponent 新增异步模板

v2 const asyncPage = () => import('./NextPage.vue')
v3:
const asyncPageWithOptions = defineAsyncComponent({
  loader: () => import('./NextPage.vue'),
  delay: 200,
  timeout: 3000,
  error: ErrorComponent,
  loadingComponent: LoadingComponent
})

4.attribute属性值得变化

v2 属性值false 会被移除
v3 会保留此属性,值为false

5.$attrs 和 $children

v2 a t t r s 是 不 包 括 c l a s s v 3 包 括 v 3 移 除 了 attrs是不包括class v3包括 v3 移除了 attrsclassv3v3children 不能用此方法访问子组件

6.自定义指令钩子得变化
前者是v2 得, v3跟vue得生命周期对应起来

created - 新的!在元素的 attribute 或事件侦听器应用之前调用。
bind → beforeMount
inserted → mounted
beforeUpdate:新的!这是在元素本身更新之前调用的,很像组件生命周期钩子。
update → 移除!有太多的相似之处要更新,所以这是多余的,请改用 updated。
componentUpdated → updated
beforeUnmount:新的!与组件生命周期钩子类似,它将在卸载元素之前调用。
unbind -> unmounted

7.v-is 自定义元素交互,用得比较少…
8.data选项

v2 data可以是对象 也可以是函数
v3 只接受返回对象得函数

9.组件可以定义发出得事件

export default {
    props: ['text'],
    emits: ['accepted']
  }

10.事件总线得移除 $on $once $once移除

11.vue3支持组件多个根节点

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

12.常用api得改变
全局 API 现在只能作为 ES 模块构建的命名导出进行访问

Vue.config —— app.config
Vue.mixin —— app.mixin
Vue.use —— app.use
Vue.prototype —— app.config.globalProperties
createApp({}).mount(‘#app’)

nextTick的变化
Vue.nextTick
Vue.observable (用 Vue.reactive 替换)
Vue.version
Vue.compile (仅全构建)
Vue.set (仅兼容构建)
Vue.delete (仅兼容构建

v2
import Vue from 'vue'
Vue.nextTick(() => {
  // 一些和DOM有关的东西
})

v3
import { nextTick } from 'vue'
nextTick(() => {
  // 一些和DOM有关的东西
})

在这里插入图片描述

13.组件注入 provide inject

v3可以在入口出 app.provide('guide', 'Vue 3 Guide') 注入
在任何组件内获取
export default {
  inject: {
    book: {
      from: 'guide'
    }
  },
  template: `<div>{{ book }}</div>`
}

14.v-for 和 v-if的变化

v2 v-for 快于 v-if
v3 v-for 慢于 v-if

错误的
<div v-for="item in list"  v-if="item.status">/<div>

15.key的改变

新增:对于 v-if/v-else/v-else-if 的各分支项 key 将不再是必须的,因为现在 Vue 会自动生成唯一的 key。
非兼容:如果你手动提供 key,那么每个分支必须使用唯一的 key。你不能通过故意使用相同的 key 来强制重用分支。
非兼容: 的 key 应该设置在 标签上 (而不是设置在它的子节点上)。

16.keyup不再支持数字

<!-- 不支持 -->
<input v-on:keyup.13="submit" />

<!-- 支持 -->
<input v-on:keyup.enter="submit" />

v-bind 的绑定顺序会影响渲染结果
常见的场景是在一个元素中同时使用 v-bind=“object” 语法和单独的 property。然而,这就引出了关于合并的优先级的问题

v2 property覆盖object
v3 根据他们的绑定前后顺序来决定

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

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

相关文章

大数据毕设选题 - 疫情实时数据分析可视化(Flask python)

文章目录1 前言1 课题背景2 数据库设计实现3 实现效果4 Flask框架5 爬虫6 Ajax技术7 Echarts8 最后1 前言 &#x1f525; Hi&#xff0c;大家好&#xff0c;这里是丹成学长的毕设系列文章&#xff01; &#x1f525; 对毕设有任何疑问都可以问学长哦! 这两年开始&#xff0c…

后端学习 - Zookeeper Kafka

实习项目用到了 Kafka&#xff0c;系统学习一下 文章目录Zookeeper一 概述二 数据结构和监听行为三 功能实现1 统一配置管理2 统一命名管理3 分布式锁4 集群管理Kafka一 系统架构1 架构图2 数量关系3 Consumer 重要参数二 工作流程1 消息写入过程2 数据不丢失&#xff1a;ACK、…

邯郸百亿斤粮食生产 国稻种芯·中国水稻节:河北大市粮食经

邯郸百亿斤粮食生产 国稻种芯中国水稻节&#xff1a;河北大市粮食经 记者黄涛、袁柯 人民网石家庄电 杨文娟 科技日报 新闻中国采编网 中国新闻采编网 谋定研究中国智库网 中国农民丰收节国际贸易促进会 国稻种芯中国水稻节 中国三农智库网-功能性农业农业大健康大会报道&…

Android Material Design之MaterialToolbar(三)

上图 引入 implementation com.google.android.material:material:1.4.0属性 属性描述app:menu右侧菜单文件app:navigationIcon左侧返回按钮app:title主标题栏文本app:titleCentered主标题栏文本是否居中app:titleTextColor主标题栏文本颜色app:subtitle子标题栏文本app:s…

OpenSergo ShardingSphere 社区共建微服务视角的数据库治理标准

作者&#xff1a;赵奕豪&#xff08;宿何&#xff09; 为什么需要微服务治理与 OpenSergo&#xff1f; 在经典微服务架构中&#xff0c;我们通常将服务调用中各角色划分为三部分&#xff1a;服务提供者、服务消费者、注册中心。经典的微服务架构可以解决微服务能调通、可以运…

我的家乡潍坊HTML静态网页 学生个人网页设计作品 学生家乡网页模板 简单个人主页成品

家乡旅游景点网页作业制作 网页代码运用了DIV盒子的使用方法&#xff0c;如盒子的嵌套、浮动、margin、border、background等属性的使用&#xff0c;外部大盒子设定居中&#xff0c;内部左中右布局&#xff0c;下方横向浮动排列&#xff0c;大学学习的前端知识点和布局方式都有…

ESP8266 如何使用 GPIO13 GPIO15 进行 UART0 通信?

1. 修改默认的日志输出串口 UART0 为 UART1 使用 ESP8266 UART1&#xff08;GPIO2&#xff09;作为程序日志输出串口&#xff0c;可进行如下配置&#xff1a; menuconfig -> Component Config -> Common ESP-related Channel for console output -> Custom UARTUART…

蓝桥杯第十四届第二期题目【Java解析】

目录 ✏️写在前面 ✨历史回顾 &#x1f388;第一题&#xff08;二进制API&#xff09; 代码&#xff1a; 思路&#xff1a; &#x1f388;第二题&#xff08;闰年问题/时间API&#xff09; 代码1&#xff1a; 思路1&#xff1a; 代码2&#xff1a; 思路2&#xff1a…

【软件测试】出现频率最高,软件测试问题,所有考虑的解答......

目录&#xff1a;导读前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09;前言 XXX岁&#xff0c;可…

【C++】经典二叉树面试题

二叉树前中后序遍历的实现 1.非递归实现 1 我们先回顾一下三种遍历&#xff1a; 前序遍历&#xff1a;根->左->右&#xff1a; F-C-A -D-B-E-H-G-M中序遍历&#xff1a;左->根->右&#xff1a; A-C-B-D-F-H-E-M-G后序遍历&#xff1a;左->右->根&#xf…

与“改善”形成两个轮子。落实“改善”的东西

与“改善”形成两个轮子。落实“改善”的东西 简单地说&#xff0c;“用心”不只是“用心”&#xff0c;科学地推进的思考就是“自工程完结”。这是一种彻底、科学地思考“只能做好工作”“只能做出好东西”的条件是什么。 “改善”、“QC循环”、“丰田生产方式”等&#xff…

Java常量:Java常量的定义和分类

常量是指在程序的整个运行过程中值保持不变的量。在这里要注意常量和常量值是不同的概念&#xff0c;常量值是常量的具体和直观的表现形式&#xff0c;常量是形式化的表现。通常在程序中既可以直接使用常量值&#xff0c;也可以使用常量。 Java入门基础视频教程&#xff0c;ja…

物联网智能家居总体设计与实现

物联网智能家居突出特点就在于家居都连接入网&#xff0c;且都可以通过一定手段进行智能控制。 图3-1 物联网智能家居框架 如图3-1所示&#xff0c;构建了一个现代家庭中所涉及到的所有物联网智能家居相关的框架。包括了安防、照明、互联网、影音、饮水、停车等方方面面。下面本…

深入理解MySQL索引的数据结构和事务的四大特性、隔离性的四种级别

1.索引1.2 使用索引2.索引的数据结构【重点】3. 事务3.1 使用3.2 事务的四大特性1.索引 概念 索引是一种特殊的文件,饱含着对数据表里所有记录的引用指针。可以对表中的一列或者多列创建索引&#xff0c;并指定索引的类型&#xff0c;各类索引有各自的数据结构实现。 作用 …

Linux学习-46-LVM逻辑卷管理机制

11.9 LVM逻辑卷管理机制&#xff08;硬盘分区管理&#xff09; 我们在实际使用 Linux 服务器的时候&#xff0c;随着业务的增加&#xff0c;文件系统负载会越来越大&#xff0c;当到了空间不足的情况时&#xff0c;如果我们还在使用传统的分区方式管理硬盘&#xff0c;就不得不…

项目管理的核心是什么?

管理的核心是目标管理 目标管理通俗来讲是对做什么的思考&#xff0c;作为管理者在面向业务的开展过程中&#xff0c;根据业务的动态调整目标&#xff0c;大目标不变的情况下&#xff0c;去不断思考做什么更好地完成目标。 目标发展的几个阶段 1、相关的概念 项目启动&…

做测试8年,刚升主管,还是没逃过裁员....

我做测试8年&#xff0c;半年前被升为测试部门主管&#xff0c;本以为马上到达人生巅峰&#xff0c;没想到公司今天通知跟我解约。 回想晋升的这半年&#xff0c;我也曾激情满满&#xff0c;想着一定要好好干出一番成绩。可做了之后才发现这是个坑&#xff1a; 每天不是在开会…

一个简单的HTML网页 故宫学生网页设计作品 dreamweaver作业静态HTML网页设计模板 旅游景点网页作业制作

家乡旅游景点网页作业制作 网页代码运用了DIV盒子的使用方法&#xff0c;如盒子的嵌套、浮动、margin、border、background等属性的使用&#xff0c;外部大盒子设定居中&#xff0c;内部左中右布局&#xff0c;下方横向浮动排列&#xff0c;大学学习的前端知识点和布局方式都有…

计算机网络第七章知识点回顾(自顶向下)

第七章知识点回顾1.网络层1.1网络层服务1.1.1网络层的两个主要功能1.1.2选路和转发的关系1.2网络层: 数据面和控制面1.网络层 Chapter goals: 理解网络层服务原理&#xff0c;主要关注数据面 网络层服务模型网络层上的重要功能&#xff1a;转发和选路路由器工作原理编址因特网…

【linux】cpu过高解决方法

CPU过高情况&#xff1a; 1、使用top命令查看cpu的进程占用情况&#xff1a; 2、发现11443的进程占比过高&#xff0c;通过top -Hp 11443 查看线程的占用情况&#xff0c;发现11459、11460、11461线程的占比过高&#xff1a; 解决swap占用CPU&#xff1a; 设置vm.swappiness0…