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>
相关推荐
毕设源码-朱学姐2 小时前
【开题答辩全过程】以 工厂能耗分析平台的设计与实现为例,包含答辩的问题和答案
java·vue.js
老前端的功夫3 小时前
Vue 3 性能深度解析:从架构革新到运行时的全面优化
javascript·vue.js·架构
天天扭码4 小时前
如何实现流式输出?一篇文章手把手教你!
前端·aigc·ai编程
前端 贾公子4 小时前
vue移动端适配方案 === postcss-px-to-viewport
前端·javascript·html
GISer_Jing5 小时前
AI营销增长:4大核心能力+前端落地指南
前端·javascript·人工智能
明远湖之鱼5 小时前
一种基于 Service Worker 的渐进式渲染方案的基本原理
前端
前端小端长6 小时前
Vue 中 keep-alive 组件的原理与实践详解
前端·vue.js·spring
FeelTouch Labs6 小时前
Nginx核心架构设计
运维·前端·nginx
雪球工程师团队7 小时前
别再“苦力”写后台,Spec Coding “跑” 起来
前端·ai编程