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 分钟前
【鲲苍提效】全面洞察用户体验,助力打造高性能前端应用
前端·前端监控
花海如潮淹9 分钟前
前端性能追踪工具:用户体验的毫秒战争
前端·笔记·ux
_丿丨丨_5 小时前
XSS(跨站脚本攻击)
前端·网络·xss
天天进步20155 小时前
前端安全指南:防御XSS与CSRF攻击
前端·安全·xss
呼啦啦呼啦啦啦啦啦啦6 小时前
利用pdfjs实现的pdf预览简单demo(包含翻页功能)
android·javascript·pdf
拾光拾趣录8 小时前
括号生成算法
前端·算法
拾光拾趣录8 小时前
requestIdleCallback:让你的网页如丝般顺滑
前端·性能优化
前端 贾公子8 小时前
vue-cli 模式下安装 uni-ui
前端·javascript·windows
拾光拾趣录9 小时前
链表合并:双指针与递归
前端·javascript·算法
@大迁世界9 小时前
前端:优秀架构的坟墓
前端·架构