ts 给 document.body 扩展属性和方法

ts版本4.1.6

document.body.abc = 666
document.body.fn = () => {
  console.log('fn')
}
// 如上,ts中,我想给document.body添加全局变量和方法,需要怎么处理?
interface Document{
  body:{
    abc: any, // err
  }
}
阅读 3.7k
3 个回答
interface HTMLBodyElement {
    myVar: string;
}


(document.body as HTMLBodyElement).myVar = "hello";
interface HTMLElement {
  //xxx
}

相较类型断言, 更好的方式是使用 Module Augmentation

declare global {
  interface HTMLElement {
    abc: number;
    fn(): void;
  }
}

document.body.abc = 666;
document.body.fn = function () {
  console.log('fn');
};

export { }

image.png

TS Playground

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进