vue3基本使用笔记(汇集精华版)

本文详细介绍了Vue3的优点,如更快的渲染速度、更好的内存管理和更小的打包体积。重点讲解了Vue3的新特性,如setup函数、Composition API、响应式数据的创建与管理,以及Vue3与Vue2在响应式实现原理上的区别。此外,还涵盖了生命周期钩子、组件间通信、Suspense组件的使用等关键知识点。
摘要由CSDN通过智能技术生成

Vue3

Vue3优点

1.首次渲染更快

2.diff算法更快

  • 因为vue2中的虚拟dom是进行全量的对比,而vue3中新增了静态标记,只比对带有PF的节点,并且通过Flag的信息得知当前节点要比对的具体内容

3.内存渲染更好

4.打包的体积更小

5.更好的TS支持

6.template中不用在嵌套一层根标签

  • 因为内部会将多个标签包含在一个Fragment的虚拟元素中 ,且该元素不会再dom树中呈现
template>
    <div>芜湖</div>
    <div>起飞</div>
</template>

7.组合式API,vue2则是选项是API ; 组合式api可以提高组件复用性 更好维护

img

Vue3中的main文件挂在组件

import {
    createApp } from 'vue'
import App from './App.vue'
// 根据App组件创建一个应用实例
const app = createApp(App)
// app应用挂载(管理)index.html的 #app 容器
app.mount('#app')

注意:vue3中的是使用的createApp()管理容器,不是new Vue()

setup函数

setup函数是vue3中特有函数,作为api中的起点 ; 从组件生命周期看,它在beforeCreate 之前执行

函数中的this不是组件实例,是undefined ; 如果数据或者函数在模板中使用,需要setup返回

<template>
  <div class="container">
    <h1 @click="say()">{
   {
   msg}}</h1>
  </div>
</template>

<script>
export default {
   
  setup () {
   
      
      return{
   }
  }
}
</script>

注意:在vue3中的setup中用不到this,所有东西通过函数获取

setup语法糖

为了让代码更加简洁,可以用语法糖 ; 这样省略了导出配置项,setup函数声明和需要return数据

<template>
  <button @click="toggle">显示隐藏图片</button>
  <img v-show="show" alt="Vue logo" src="./assets/logo.png" />
  <hr />
  计数器:{
  { count }} <button @click="increment">累加</button>
</template>

<script setup>
  // 显示隐藏
  const show = ref(true)
  const toggle = () => {
    show.value = !show.value
  }
  // 计数器
  const count = ref(0)
  const increment = () => {
    count.value ++
  }
</script>

注意:script setup中的变量也可以直接在模板中使用

reactive函数

使用reactive定义对象数组类型的响应式数据

使用:

  • vue中导出reactive函数
  • setup函数中,使用reactive函数,传入一个普通对象,返回一个响应式数据对象
  • 最后在setup函数中返回一个对象,包含该响应式对象就可以在模板中使用
<template>
  <div>
    <p>姓名:{
   {
   state.name}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值