[Typescript] ThisType

This utility does not return a transformed type. Instead, it serves as a marker for a contextual this type. Note that the noImplicitThis flag must be enabled to use this utility.

type Math = {
  double(): void,
  half(): void
}

const math:Math = {
  double(this: {value: number}) { // we have to tell what this is
    this.value *= 2
  },
  half(this: {value: number}) { // we have to tell what this is
    this.value /= 2
  }
}

const obj = {
  value: 1,
  ...math
}

obj.double()
console.log(obj.value)

obj.half()
console.log(obj.value)

 

We don't actually want to write this: {value: number}again and again.

 

So what we can do:

const math: Math & ThisType<{value: number}> = {
  double() {
    this.value *= 2
  },
  half() {
    this.value /= 2
  }
}

 

Two appraoch are the same, just by using Typescript utilites type ThisType<>, can simply our code.

 

posted @   Zhentiw  阅读(63)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2020-11-08 [Kotlin] Mapping between two entities
2018-11-08 [Node.js] Trigger a File Download in Express
2018-11-08 [WASM Rust] Create and Publish a NPM Package Containing Rust Generated WebAssembly using wasm-pack
2017-11-08 [TypeScript] Restrict null and undefined via Non-Nullable-Types in TypeScript
2017-11-08 [PWA] Deal with caches in PWA
2016-11-08 [AngularJS] Using an AngularJS directive to hide the keyboard on submit
2016-11-08 [Javascript Natural] Break up language strings into parts using Natural
点击右上角即可分享
微信分享提示