掌握 Vue 3 的 <script setup>:高效开发的必备技巧

news2025/1/12 20:56:34

<script setup> 是 Vue 3 引入的一种新的 <script> 标记的用法,其本质是一个语法糖。它极大简化了单文件组件(SFC)的开发体验,目的是让代码更简洁、易读,同时减少模板和逻辑之间的重复。

1. 基本用法

<!-- 使用 <script setup> -->
<template>
  <div>
    <p>message: {{ message }}</p>
    <button @click="handleClick" style="margin-top: 10px; padding: 2px 6px;">点击我</button>
  </div>
</template>

<script setup>
import { ref } from 'vue';
// 定义响应式变量
const message = ref('Hello, Setup!');
// 定义一个方法
const handleClick = () => {
  message.value = '点击按钮!';
};
</script>
<!-- 使用之前的方式 -->
<template>
  <div>
    <p>message: {{ message }}</p>
    <button @click="handleClick" style="margin-top: 10px; padding: 2px 6px">点击我</button>
  </div>
</template>

<script>
import { ref } from 'vue'
export default {
  setup() {
    const message = ref('Hello, Setup!')
    const handleClick = () => {
      message.value = '点击按钮!'
    }
    return {
      message,
      handleClick
    }
  }
}
</script>

从这个简单的例子可以看出, <script setup> 让代码更加简洁易懂。

2. 特点

1、自动绑定上下文,简化导入和使用

在 <script setup> 中,所有的变量、函数、引入的库都自动绑定到模版的上下文中,无需显式返回,可以直接在模版中使用。

2、优化编译性能

<script setup> 在编译阶段进行了大量的优化,减少运行时开销。

3、更好的类型推断

当使用 TypeScript 时, <script setup> 让类型推断更加精确,开发体验更好。

<template>
  <div>
    <p>当前计数: {{ count }}</p>
    <button @click="increment">增加</button>
  </div>
</template>

<script setup lang="ts">
import { ref } from 'vue'
const count = ref<number>(0)
const increment = (): void => {
  count.value++
}
</script>

在 <script setup> 中加上 lang = 'ts',即表明这个文件是用 TypeScript 编写的,这样可以启用 TS 的类型检查和推断功能。 

3. 对比传统 <script> 

1、组件注册不需要手动处理,默认注册完成。

2、不需要使用 export default。

3、不需要使用 return 显式返回,<script setup> 最外层定义的对象、函数均自动返回,模版直接使用。

4、在 <script setup> 中,父组件拿不到子组件的实例成员,不能直接进行使用,这也是 vue 官方推荐的方法。可以使用 defineExpose 进行暴露,和原始样式的 expose 是一样。

<!-- 子组件 -->
<template>
  <div style="border: 1px solid pink;">
    <p>当前计数:{{ count }}</p>
  </div>
</template>

<script setup>
import { ref } from 'vue'
const count = ref(0)
const incrementCount = () => {
  count.value++
}
defineExpose({
  count,
  incrementCount
})
</script>
<!-- 父组件 -->
<template>
  <div class="container">
    <h2>父组件</h2>
    <MyComponent ref="MyComponentRef" />
    <button @click="childCount" class="btn">打印子组件的计数</button>
    <button @click="incrementChildCount" class="btn">增加子组件的计数</button>
  </div>
</template>

<script setup>
import MyComponent from './components/MyComponent.vue'
import { ref } from 'vue'

const MyComponentRef = ref(null)
const childCount = () => {
  console.log('访问子组件的 count: ', MyComponentRef.value.count)
}
const incrementChildCount = () => {
  MyComponentRef.value.incrementCount()
}
</script>

5、在 <script setup> 使用 defineProps 和 defineEmits。

举个 🌰

<template>
  <div style="border: 1px solid pink;">
    <h2>子组件</h2>
    <p>message:{{ message }}</p>
    <button @click="emitEvent" style="margin-top: 10px; padding: 2px 6px;">点击我</button>
  </div>
</template>

<script setup>
import { defineProps, defineEmits } from 'vue';

const props = defineProps({
  message: String
});
const emit = defineEmits(['customEvent']);
const emitEvent = () => {
  emit('customEvent', 'message from child');
};
</script>
<template>
  <div style="border: 1px solid red;">
    <h2>父组件</h2>
    <MyComponent :message="msg" @customEvent="handleCustomEvent" />
    <p>{{ receivedMessage }}</p>
  </div>
</template>

<script setup>
import { ref } from 'vue';
import MyComponent from './components/MyComponent.vue';

const msg = ref('message from parent');
const receivedMessage = ref('');
const handleCustomEvent = (message) => {
  receivedMessage.value = `从子组件接收到的消息:${message}`;
};
</script>

4. 注意事项

1、单个 <script>

每个组件只能有一个 <script setup>,但可以同时使用 <script setup> 和 常规的 <script>,以兼容某些不支持的功能。

举个 🌰

<template>
  <div>
    <h3>Message from setup: {{ message }}</h3>
    <h3>Message from tradition script: {{ additionalMessage }}</h3>
  </div>
</template>

<script setup>
import { ref, onMounted } from 'vue'
const message = ref('message from setup!')
onMounted(() => {
  console.log('这行代码运行在 script setup 的 onMounted 钩子中')
})
</script>

<script>
export default {
  name: 'MyComponent',
  data() {
    return {
      additionalMessage: 'message from traditional script!'
    }
  },
  mounted() {
    console.log('这行代码运行在 traditional script 的 mounted 钩子中');
  }
}
</script>

2、无法使用 this

在 <script setup> 中,没有组件实例上下文的概念,因此无法使用  this 访问组件的数据、方法或计算属性。所有状态和方法都是以局部变量的方式存在。

总结:

<script setup> 是 Vue 3 的一个强大特性,简化组件的编写方式,让 Vue 组件的开发更加高效和直观。对于开发者来说,可以大大提高开发效率和代码可维护性。

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

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

相关文章

Issue with OpenAI API key while using it in Windows

题意&#xff1a;“在 Windows 上使用 OpenAI API 密钥时遇到的问题” 问题背景&#xff1a; I have to fine-tune the OpenAI model on my custom dataset. I have created the dataset in jsonl format. I use the following commands on windows command line: “我需要在…

docker 安装 oracle11g

#创建oracle11g docker run -d --name myoracle11g -p 1522:1521 akaiot/oracle_11g #登录到oracle,要先docker ps 查看具体的docker id docker exec -it 22222222 bash su root 密码&#xff1a;helowin # 设置环境变量 vi /etc/profile export ORACLE_HOME/home/oracle/ap…

谷粒商城实战笔记-236~238-商城业务-购物车-环境搭建

文章目录 一&#xff0c;236-商城业务-购物车-环境搭建二&#xff0c;237-商城业务-购物车-数据模型分析三&#xff0c;238-商城业务-购物车-VO编写 一&#xff0c;236-商城业务-购物车-环境搭建 这一节的主要内容&#xff1a; ①创建购物车模块②上传静态资源到nginx③复制静…

二分+数学,CF 689C - Mike and Chocolate Thieves

目录 一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 二、解题报告 1、思路分析 2、复杂度 3、代码详解 一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 689C - Mike and Chocolate Thieves 二、解题报告 1、思路分析 考虑一个…

钥匙失效、门卡死?看如何用电脑远程解救作业

不少人都在自己的电脑上安排了远程控制软件&#xff0c;以便在紧急情况下可以相互远程操作。原本这样的设置只是为了应对偶尔的加班需求&#xff0c;没想到今天它发挥了意想不到的作用。 就在刚才&#xff0c;一阵突如其来的狂风“咣”地一声将门牢牢锁死&#xff0c;钥匙也无法…

CeresPCL 最小二乘插值(曲线拟合)

一、简介 在多项式插值时,当数据点个数较多时,插值会导致多项式曲线阶数过高,带来不稳定因素。因此我们可以通过固定幂基函数的最高次数 m(m < n),来对我们要拟合的曲线进行降阶。之前的函数形式就可以变为: 既然是最小二乘问题,那么就仍然可以使用Ceres来进行求解。 …

禁止浏览器默认填充密码 vue

禁止浏览器默认填充密码会和我的样式冲突 所以禁止 第一种&#xff1a; 通过给表单元素添加 autocomplete"off" 属性&#xff0c; 可以防止浏览器自动填充表单中的账号和密码。可以在 input 标签或整个 form 标签上使用&#xff1a; <template><a-form&g…

基于Springboot2 + vue3酒店客房预订管理系统

笔者花大量时间设计整理出来的一套预订系统&#xff0c;【按照商业软件的标准此程序还有很多不足之处&#xff0c;需要大力改进】。本平台采用B/S结构&#xff0c;后端采用主流的JAVA Springboot框架进行开发&#xff0c;前端采用主流的Vue3 &#xff0c;vite,pinia等技术进行…

roaring 编译问题:undefined reference to `**‘

已经到了链接阶段了&#xff0c;这个显示roaring.hh中的一些函数没有定义。但是实际上已经输出了红色标出的这个信息。 并且这个库的组成是这样&#xff0c;在roaring.c中&#xff0c;都有函数的定义。 链接出问题&#xff0c;首先 make install 把库再编一下。 再看一下链接…

Java基础——自学习使用

一个程序有main方法 当自己调用main方法运行就是一个进程&#xff0c;要是依托别人的main方法运行&#xff0c;就是一个线程 通过双击刺激这个文件相关的主方法运行&#xff0c;然后将文件的地址当做参数传给主方法&#xff0c;就能打开文件了 数据类型&#xff1a;规定内存以…

由于找不到 mfc140u.dll,无法继续执行代码。重新安装程序可能会解决此问题。

安装应用程序时遇到以下问题&#xff1a;   由于找不到 mfc140u.dll&#xff0c;无法继续执行代码。重新安装程序可能会解决此问题。   mfc140u.dll 是一个属于 Microsoft Visual C Redistributable 的文件&#xff0c;‌它是许多基于 Windows 的应用程序运行时所必需的。…

零基础学习Redis(3) -- Redis常用命令

Redis是一个 客户端-服务器 结构的程序&#xff0c;Redis客户端和服务器可以在同一台主机上&#xff0c;也可以在不同主机上&#xff0c;客户端和服务器之间通过网络进行通信。服务器端负责存储和管理数据。客户端则可以通过命名对服务端的数据进行操作。 Redis客户端有多种&a…

2024年下半年,单独划定的地区报名软考的温馨提示

软考分数线分为全国分数线、省分数线&#xff08;陕西省下半年已取消&#xff0c;仅剩青海省&#xff09;、以及单独划线地区分数线。目前各地2024年下半年软考正在接受报名&#xff0c;请单独划线地区的考生注意——有些地区可能要求考生在考试后进行单独划线申请&#xff0c;…

五大无线领夹麦克风常见“智商税”揭秘:选购时务必留意

​随着科技的进步和音频市场的多元化发展&#xff0c;无线领夹麦克风已经成为了各类场合中不可或缺的工具。从专业的影视制作到日常的个人直播&#xff0c;一个优秀的无线麦克风都能极大地提升语音的清晰度和传播的效果。为了让大家更好地选择适合自己的麦克风&#xff0c;我们…

开放式耳机什么品牌好?精选五大公认王牌机型横评汇总!

很多人在通勤路上跟运动时候喜欢听音乐&#xff0c;一些音乐可以为运动增加一定的激情&#xff0c;在通勤路上没有这么久路程&#xff0c;而开放式耳机是最适合佩戴的&#xff0c;不入耳不伤耳&#xff0c;解放双耳设计&#xff0c;还能接收外界环境声&#xff0c;避免不必要事…

阿里云CentOs ClickHouse安装

&#x1f339;作者主页&#xff1a;青花锁 &#x1f339;简介&#xff1a;Java领域优质创作者&#x1f3c6;、Java微服务架构公号作者&#x1f604; &#x1f339;简历模板、学习资料、面试题库、技术互助 &#x1f339;文末获取联系方式 &#x1f4dd; ClickHouse安装目录 前言…

NO呼气检测在临床应用重要性

呼出气一氧化氮&#xff08;exhaled nitricoxide&#xff0c;eNO&#xff09;由气道上皮细胞中的一氧化氮合成酶&#xff08;nitricoxide synthase&#xff0c;NOS&#xff09;催化 L-精氨酸产生。 目前临床最常使用的呼出气流速为50ml/s时检测到的数值&#xff0c;是目前最常…

VLM调研记录

Visual Autoregressive Modeling: Scalable Image Generation via Next-Scale Prediction 北大和字节团队的一篇VLM&#xff0c;在生成任务上&#xff0c;用GPT范式&#xff0c;声称在FID上超过了DIT&#xff0c;SD3和SORA。开源。首先是multi-scale的VQVAE&#xff0c;然后是…

第二百零九节 Java格式 - Java数字格式类

Java格式 - Java数字格式类 以下两个类可用于格式化和解析数字: java.text.NumberFormatjava.text.DecimalFormat NumberFormat 类可以格式化一个数字特定地区的预定义格式。 DecimalFormat 类可以格式化数字以特定区域设置的自定义格式。 NumberFormat类的 getXXXInstance…

实战分享:服务可视化编排在交付团队中的真实作用

最近有个技术团队的CTO 交流的时候&#xff0c;聊到了逻辑引擎、API服务编排&#xff0c;他很反感逻辑的编排&#xff0c;觉得还不如写代码来得快。 对方是一个小型的交付团队&#xff0c;对方的老板&#xff08;也稍微懂一些技术&#xff0c;不是很深刻&#xff09;&#xff…