vue3中setup语法糖那些事儿

简介: vue3中setup语法糖那些事儿

vue3中setup语法糖那些事儿

什么是语法糖?

vue3相比于vue2有什么新的语法糖?

ref

reactive

watch

生命周期

Teleport

setup语法糖

`<script setup>`与传统vue3有何不同

传统vue3和setup语法糖,两者之间写法如何转换?

什么是语法糖?

⭐语法糖是指在编程语言中,一种特殊的语法形式,它并不影响语言的功能和能力,只是提供一种更加优雅、简洁、易读的语法形式,让代码更加易于理解和编写。通常,语法糖是编译器或解释器在编译或解释代码时将其转换成标准语法的过程,因此语法糖并不会增加代码的运行效率,只是提高了代码的可读性和可维护性。

在前端开发中,常见的语法糖有很多,例如:


ES6中的箭头函数,可以简化函数定义的写法;

Vue中的v-bind可以写成冒号,v-on可以写成@符号,可以简化模板中绑定事件和属性的写法;

React中的JSX语法,可以将HTML和JavaScript结合在一起,使代码更加易读。

总的来说,语法糖可以提高代码的可读性和可维护性,但也需要注意不要过度使用,以免影响代码的性能和可理解性。

vue3相比于vue2有什么新的语法糖?

⭐首先需要明确的是,vue3相比于vue2,有很多新的写法和语法糖,主要是基于Composition API的实现。

ref

Vue3中使用ref来定义响应式数据,其用法与Vue2中的data类似。

import { ref } from 'vue'
export default {
  setup() {
    const count = ref(0)
    return {
      count
    }
  }
}

reactive

reactive函数用来创建响应式对象,可以将一个普通对象转换为响应式对象。与Vue2中的computed类似,Vue3中的computed也是基于reactive实现的。

import { reactive, computed } from 'vue'
export default {
  setup() {
    const state = reactive({
      count: 0,
      doubleCount: computed(() => state.count * 2)
    })
    return {
      state
    }
  }
}

watch

Vue3中的watch函数可以监听响应式数据的变化,其用法与Vue2中的watch类似。

import { watch } from 'vue'
export default {
  setup() {
    const count = ref(0)
    watch(count, (newValue, oldValue) => {
      console.log(`count的值从${oldValue}变为${newValue}`)
    })
    return {
      count
    }
  }
}

生命周期

在Vue3中,生命周期钩子函数被重构为setup函数中的普通函数,例如created钩子函数可以被拆分为beforeCreatecreated两个函数

import { onBeforeCreate, onCreated } from 'vue'
export default {
  setup() {
    onBeforeCreate(() => {
      console.log('组件实例创建之前')
    })
    onCreated(() => {
      console.log('组件实例创建之后')
    })
    return {}
  }
}

Teleport

Vue3中新增了Teleport组件,用于将组件的内容插入到指定的DOM节点中,其用法与Vue2中的slot类似

<template>
  <teleport to="body">
    <div>Teleport到body中了</div>
  </teleport>
</template>

setup语法糖

⭐⭐setup函数是Vue3中的新特性,它是用来替代Vue2中的data、computed、watch等选项的,是一种新的组件选项。可以说,setup函数是Vue3中最重要的语法糖之一。setup函数是一个普通的函数,它接收两个参数:props和context。其中,props是组件的属性对象,context是组件的上下文对象,包含了一些Vue3的API。


在setup函数中,我们可以使用Vue3提供的Composition API来定义组件的响应式数据、计算属性、方法、生命周期钩子等。与Vue2中的选项不同,setup函数中的代码是纯粹的JavaScript代码,易于理解和维护。


除此之外,setup函数还有以下特点:


setup函数的返回值是一个对象,对象中的属性和方法可以在模板中直接使用。

setup函数中的响应式数据必须使用ref、reactive等API来创建,不能直接定义在setup函数中。

setup函数中的计算属性和方法可以直接定义为普通函数,无需使用computed和methods选项。

setup函数中的生命周期钩子函数也被重构了,可以使用onBeforeMount、onMounted等API来定义。

<script setup>与传统vue3有何不同

<script setup>是Vue 3中的新特性,它旨在简化单文件组件的编写。相较于传统Vue 3中的<script>标签,<script setup>具有以下不同点:不需要导入vue模块:在<script>标签中使用Vue时需要导入vue模块,而在<script setup>中不需要。

不需要定义data、computed、methods等选项:在<script>标签中需要通过data函数来定义响应式数据,在computed和methods选项下定义计算属性和方法。但是在<script setup>中可以直接使用响应式变量和计算属性,这些变量和属性都会被自动处理为响应式的。

props和context对象自动注入:在<script setup>中可以直接使用props和context对象,无需通过参数或者导入来获取。

单文件组件支持更多类型:除了.vue文件之外,还支持使用.tsx和.jsx文件作为单文件组件,并且可与<script setup>一起使用。

⭐⭐⭐将传统Vue 3代码转换为<script setup>代码时,主要做法总结一下,大概有4种:

⭐第一种:将原先放置于data选项下的响应式变量直接声明即可,例如将

 data: () => ({ 
   num: 10
  })

替换为

const num = ref(10)

⭐第二种:计算属性可以直接作为函数声明并返回值;方法也可以直接声明成函数


⭐第三种:在<template>标签中使用的响应式变量和计算属性,需要通过defineExpose暴露出来才能在父组件中使用。比如说:

const state = reactive({ 
  count: 0 
}); 
defineExpose({ state });

⭐第四种:propscontext对象直接在函数参数中声明即可

生命周期函数与传统Vue 3写法相同,可以继续使用

传统vue3和setup语法糖,两者之间写法如何转换?

在这里,我直接上一段代码说明一下。

传统vue3写法:

<template>
  <div>{{ count }}</div>
</template>
<script>
import { reactive } from "vue";
export default {
  data: () => ({
    count: 0
  }),
  methods: {
    increment() {
      this.count++;
    }
  },
  created() {
    console.log('语法糖你好');
  }
};
</script>

setup语法糖的写法

<template>
  <div>{{ count }}</div>
</template>
<script setup>
import { ref, onMounted } from 'vue'
let count = ref(0)
function increment() {
   count.value++
}
onMounted(() => {
   console.log('语法糖你好')
})
</script setup>

这种技术,写法,观念的更新其实是很好的,一时半会难以接受很正常。但是新写法会使得我们的代码更加简洁、灵活、易于维护。也使我们能够更好地组织代码,提高开发效率。

为语法糖干杯!

相关文章
|
12天前
|
开发工具 iOS开发 MacOS
基于Vite7.1+Vue3+Pinia3+ArcoDesign网页版webos后台模板
最新版研发vite7+vue3.5+pinia3+arco-design仿macos/windows风格网页版OS系统Vite-Vue3-WebOS。
144 11
|
2月前
|
缓存 前端开发 大数据
虚拟列表在Vue3中的具体应用场景有哪些?
虚拟列表在 Vue3 中通过仅渲染可视区域内容,显著提升大数据列表性能,适用于 ERP 表格、聊天界面、社交媒体、阅读器、日历及树形结构等场景,结合 `vue-virtual-scroller` 等工具可实现高效滚动与交互体验。
272 1
|
2月前
|
缓存 JavaScript UED
除了循环引用,Vue3还有哪些常见的性能优化技巧?
除了循环引用,Vue3还有哪些常见的性能优化技巧?
149 0
|
3月前
|
JavaScript
vue3循环引用自已实现
当渲染大量数据列表时,使用虚拟列表只渲染可视区域的内容,显著减少 DOM 节点数量。
99 0
|
5月前
|
JavaScript 前端开发 API
Vue 2 与 Vue 3 的区别:深度对比与迁移指南
Vue.js 是一个用于构建用户界面的渐进式 JavaScript 框架,在过去的几年里,Vue 2 一直是前端开发中的重要工具。而 Vue 3 作为其升级版本,带来了许多显著的改进和新特性。在本文中,我们将深入比较 Vue 2 和 Vue 3 的主要区别,帮助开发者更好地理解这两个版本之间的变化,并提供迁移建议。 1. Vue 3 的新特性概述 Vue 3 引入了许多新特性,使得开发体验更加流畅、灵活。以下是 Vue 3 的一些关键改进: 1.1 Composition API Composition API 是 Vue 3 的核心新特性之一。它改变了 Vue 组件的代码结构,使得逻辑组
1509 0
|
15天前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
134 2
|
4月前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
571 0
|
4月前
|
JavaScript UED
用组件懒加载优化Vue应用性能
用组件懒加载优化Vue应用性能
|
5月前
|
JavaScript 数据可视化 前端开发
基于 Vue 与 D3 的可拖拽拓扑图技术方案及应用案例解析
本文介绍了基于Vue和D3实现可拖拽拓扑图的技术方案与应用实例。通过Vue构建用户界面和交互逻辑,结合D3强大的数据可视化能力,实现了力导向布局、节点拖拽、交互事件等功能。文章详细讲解了数据模型设计、拖拽功能实现、组件封装及高级扩展(如节点类型定制、连接样式优化等),并提供了性能优化方案以应对大数据量场景。最终,展示了基础网络拓扑、实时更新拓扑等应用实例,为开发者提供了一套完整的实现思路和实践经验。
545 77
|
3月前
|
JavaScript 安全
在 Vue 中,如何在回调函数中正确使用 this?
在 Vue 中,如何在回调函数中正确使用 this?
111 0

热门文章

最新文章