Vue3 <script setup> 中,async 通常不能省略

在Vue3的<script setup>中,async关键字的使用取决于场景:

  1. 使用await时必须加async;
  2. 使用.then()或同步操作时可省略;
  3. Vue3.3+支持顶层await无需async。

async的作用是让函数返回Promise并允许使用await。


若代码含await却省略async会导致语法错误。


文中提供了具体代码示例说明何时必须或可以省略async关键字。


<script setup lang="ts"> 中,async 通常不能省略,但有特殊情况。


1. 需要 async 的情况(最常见)

当你需要在 onMountedwatchcomputed 等钩子或响应式API中使用 await 时:

TypeScript 复制代码
// ✅ 必须要有 async
onMounted(async () => {
  const data = await fetchData()  // 使用 await
  result.value = data
})

// ✅ 必须要有 async  
const fetchData = async () => {
  const response = await axios.get('/api/data')
  return response.data
}

2. 可以省略 async 的情况

方式一:使用 .then() 替代 await

TypeScript 复制代码
// ✅ 可以省略 async
onMounted(() => {
  fetchData().then(data => {
    result.value = data
  })
})

方式二:不使用异步操作

TypeScript 复制代码
// ✅ 可以省略 async
onMounted(() => {
  result.value = '立即设置的值'
})

3. 针对你的原始代码

TypeScript 复制代码
// 原始代码(必须要有 async)
onMounted(async () => {
  result.value = await new Promise<string>((resolve) => {
    setTimeout(() => {
      resolve('hello world')
    }, 10000)
  })
})

// 等价改写(可以省略 async)
onMounted(() => {
  new Promise<string>((resolve) => {
    setTimeout(() => {
      resolve('hello world')
    }, 10000)
  }).then(value => {
    result.value = value  // 使用 .then() 替代 await
  })
})

4. async 的作用

async 关键字的作用是:

  1. 让函数返回一个 Promise

  2. 允许在函数内部使用 await

  3. 自动包装返回值为 Promise

TypeScript 复制代码
// 这两个函数是等价的
async function foo() { return 1 }
function foo() { return Promise.resolve(1) }

5. ue 3.3+ 的特殊情况

Vue 3.3+ 引入了 <script setup> 的顶层 await 支持:

TypeScript 复制代码
<script setup lang="ts">
// ✅ Vue 3.3+ 支持,不需要 async
const data = await fetchData()  // 顶层 await

// 但生命周期钩子内仍需 async
onMounted(async () => {
  // ...
})
</script>

总结:

场景 是否需要 async
使用 await 必须
使用 .then() 不需要
同步操作 不需要
Vue 3.3+ 顶层 await 不需要(在顶层)

在你的代码中,由于使用了 await,所以 async 不能省略。 如果省略了 async,但保留了 await,会导致语法错误。

相关推荐
Lkstar2 小时前
Vue keep-alive 原理全解:LRU 缓存策略、源码级理解
前端·vue.js·面试
代码煮茶4 小时前
Vue3 埋点实战 | 从 0 搭建前端用户行为埋点系统
vue.js
鱼樱前端5 小时前
我做了一个不止有基础组件的 Vue 3 UI 库,还把 AI 组件也做进去了
前端·vue.js·ai编程
徐小夕6 小时前
面试官:AI生成到90%突然断了,你的解决方案是什么?(万字长文深度剖析)
前端·vue.js·算法
ljt27249606618 小时前
Vue笔记(六)--响应式
javascript·vue.js·笔记
天蓝色的鱼鱼9 小时前
尤雨溪亲自点赞!用 Vue 3 写原生 App,这个框架终于来了!
前端·vue.js
你听得到1110 小时前
从 Figma 走查到 AI 可验证产物:我如何重构客户端 UI 交付链路
前端·vue.js·flutter
卤蛋fg610 小时前
vxe-select 下拉框实现人员选择
vue.js
用户8417948145610 小时前
vxe-select 下拉框实现带单选框/复选框勾选功能
vue.js
_xaboy11 小时前
开源Vue组件 FormCreate 使用组件内部方法校验
前端·vue.js·开源