11类型断言

有时候你会比 TS 更加明确一个值的类型,此时,可以使用类型断言来指定更具体的类型。 比如,

// aLink 的类型 HTMLElement,该类型只包含所有标签公共的属性或方法
// 这个类型太宽泛,没包含 a 元素特有的属性或方法,如 href
const aLink = document.getElementById('link')
  • 但是我们明确知道获取的是一个 A 元素,可以通过 类型断言 给它指定一个更具体的类型。

const aLink = document.getElementById('link') as HTMLAnchorElement
  • 解释:

    1. 使用 as 关键字实现类型断言

    2. 关键字 as 后面的类型是一个更加具体的类型(HTMLAnchorElement 是 HTMLElement 的子类型)

    3. 通过类型断言,aLink 的类型变得更加具体,这样就可以访问 a 标签特有的属性或方法了

例如:

const img = document.getElementById('img') as HTMLImageElement
// 如果不知道标签的类型:document.querySelector('div') 鼠标摸上去就可以看见

场景2:获取后台默认值

type Response={
    msg:string
    data:[}
}

let data:Response={}//会报错提示没有定义这两个元素

let data={} as Response//不会报错

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这错误提示是Uncaught ReferenceError: Processing is not defined,出现在HTMLAnchorElement.onclick上。根据提供的资料,问题的原因可能是在点击事件中的onclick函数中使用了一个未定义的变量Processing。由于没有提供足够的上下文信息,我无法确定具体原因。但是,一般情况下,这种错误可能是由于以下几种情况引起的: 1. 变量名拼写错误:请检查代码中的变量名是否正确拼写,确保在使用之前已经定义。 2. 变量作用域问题:请确保变量在点击事件的作用域内定义或引入,以便在onclick函数中访问。 3. 变量未加载:如果使用的是外部库或框架,确保该库或框架已正确加载,并且变量在加载之后可用。 综上所述,要解决这个错误,你可以检查代码中的变量拼写、作用域和加载顺序等方面的问题。如果仍然无法解决,建议提供更多的代码或上下文信息,以便我能够更准确地帮助你找到问题所在。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Uncaught ReferenceError: is not defined at HTMLAnchorElement.onclick](https://blog.csdn.net/shangguanliubei/article/details/109893583)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [easyui解决:Uncaught ReferenceError: jQuery is not defined](https://download.csdn.net/download/weixin_38750761/14044307)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值