web前端全系列 教程
1839个小节阅读:2244.2k
目录
鸿蒙应用开发
C语言快速入门
JAVA全系列 教程
面向对象的程序设计语言
Python全系列 教程
Python3.x版本,未来主流的版本
人工智能 教程
顺势而为,AI创新未来
大厂算法 教程
算法,程序员自我提升必经之路
C++ 教程
一门通用计算机编程语言
微服务 教程
目前业界流行的框架组合
web前端全系列 教程
通向WEB技术世界的钥匙
大数据全系列 教程
站在云端操控万千数据
AIGC全能工具班
A A
White Night
在处理原生 DOM 事件时,应该为我们传递给事件处理函数的参数正确地标注类型
xxxxxxxxxx
<template>
<button @click="clickHandler">按钮</button>
</template>
<script lang="ts">
import { defineComponent } from "vue"
export default defineComponent({
methods:{
clickHandler(e){
// `event` 隐式地标注为 `any` 类型
console.log(e.target)
}
}
})
</script>
没有类型标注时,这个 event
参数会隐式地标注为 any
类型。这也会在 tsconfig.json
中配置了 "strict": true
或 "noImplicitAny": true
时抛出一个 TS 错误。因此,建议显式地为事件处理函数的参数标注类型。此外,你可能需要显式地强制转换 event
上的属性
xxxxxxxxxx
<template>
<button @click="clickHandler">按钮</button>
</template>
<script lang="ts">
import { defineComponent } from "vue"
export default defineComponent({
methods:{
clickHandler(e:Event){
// `event` 隐式地标注为 `any` 类型
console.log((e.target as HTMLButtonElement).innerHTML)
}
}
})
</script>