Vue3:【props、emit 和 components】 在 setup 语法糖和非语法糖中的使用

目录

  • [1 props](#1 props)
    • [1.1 setup 语法糖](#1.1 setup 语法糖)
    • [1.2 非语法糖](#1.2 非语法糖)
  • [2 emit](#2 emit)
    • [2.1 setup 语法糖](#2.1 setup 语法糖)
    • [2.2 非语法糖](#2.2 非语法糖)
  • [3 components 组件](#3 components 组件)
    • [3.1 语法糖](#3.1 语法糖)
    • [3.2 非语法糖](#3.2 非语法糖)

1 props

1.1 setup 语法糖

ts 复制代码
<script lang="ts" setup>

interface PersionItem {
  id: number
  value: number
  imageSrc: string
  label: string
}
const props = defineProps({
  personData: {
    type: Array as () => PersionItem[],
    default: () => []
  }
})

console.log(props.personData)

1.2 非语法糖

typescript 复制代码
<script lang="ts">

interface Option {
  imageSrc: String
  fileName: String
  modifierInfo: String
  path: String
  origin: String
}
export default {
  props: {
    listData: {
      type: Array as () => Option[],
      default: () => []
    }
  },
  setup(props, { emit }) {
    console.log(props.listData)
    return {}
  }
}
</script>

2 emit

2.1 setup 语法糖

typescript 复制代码
<script lang="ts" setup>
import { defineEmits } from 'vue'
// 定义
const emit = defineEmits(['checkPerson'])

const check = () => {
  emit('checkPerson', personID.value)
}
</script>

2.2 非语法糖

typescript 复制代码
<script lang="ts">
export default {
  emits: ['focusEvent', 'blurEvent'],
  setup(props, { emit }) {
    // const emit = defineEmits(['debouncedInput', 'focusEvent', 'blurEvent'])
    // 获得焦点事件
    const focusFn = () => {
      emit('focusEvent')
    }
    // 失去焦点事件
    const blurFn = () => {
      emit('blurEvent')
    }

    return {  focusFn, blurFn }
  }
}
</script>

3 components 组件

3.1 语法糖

引入后直接用

3.2 非语法糖

typescript 复制代码
<script lang="ts">
import fileNameItem from './fileNameItem.vue'

export default {
  // 局部注册组件
  components: {
    fileNameItem
  },
  setup(props, { emit }) {
    return {}
  }
}
</script>
相关推荐
政采云技术17 分钟前
音视频通用组件设计探索和应用
前端·音视频开发
不爱吃糖的程序媛19 分钟前
Electron 如何判断运行平台是鸿蒙系统(OpenHarmony)
javascript·electron·harmonyos
Hilaku35 分钟前
我用AI重构了一段500行的屎山代码,这是我的Prompt和思考过程
前端·javascript·架构
Cxiaomu36 分钟前
React Native App 自动检测版本更新完整实现指南
javascript·react native·react.js
IT_陈寒1 小时前
Vite性能优化实战:5个被低估的配置让你的开发效率提升50%
前端·人工智能·后端
IT_陈寒1 小时前
Java性能调优的7个被低估的技巧:从代码到JVM全链路优化
前端·人工智能·后端
掘金安东尼1 小时前
前端周刊第439期(2025年11月3日–11月9日)
前端·javascript·vue.js
码农刚子2 小时前
ASP.NET Core Blazor进阶1:高级组件开发
前端·前端框架
有蝉2 小时前
vue-office——支持多种文件(docx、excel、pdf)预览的vue组件库,支持vue2/3。也支持非Vue框架的预览。
vue.js·pdf·excel
道可到2 小时前
重新审视 JavaScript 中的异步循环
前端