TypeScript遍历对象属性的问题

 更新时间:2021年11月11日 09:48:05   作者:guo&qi  
这篇文章主要介绍了TypeScript遍历对象属性的问题,文章围绕TypeScript遍历对象属性的相关资料展开详细内容,需要的朋友可以参考一下

一、问题 

 比如下面的代码:

type Animal = {
    name: string;
    age: number
}

const animal:Animal={
    name:"dog",
    age:12
}

function test(obj:Animal) {
    for (let k in obj) {
        console.log(obj[k])。//这里出错
    }
}
test(animal)

报错:

二、解决办法

1. 把对象声明as any

function test(obj:Animal) {
    for (let k in obj) {
        console.log((obj as any)[k]) //不报错
    }
}


  这个方法直接绕过了typescript的校验机制

2. 给对象声明一个接口

type Animal = {
    name: string;
    age: number;
    [key: string]: any
}

const animal:Animal={
    name:"dog",
    age:12
}

function test(obj:Animal) {
    for (let k in obj) {
        console.log(obj [k]) //不报错
    }
}
test(animal)

  这个可以针对比较常见的对象类型,特别是一些工具方法。

3. 使用泛型

function test<T extends object>(obj:T) {
    for (let k in obj) {
        console.log(obj [k]) //不报错
    }
}

4. 使用keyof

function test(obj:Animal) {
    let k: (keyof Animal);
    for (k in obj) {
        console.log(obj [k]) //不报错
    }
}

到此这篇关于TypeScript遍历对象属性的问题的文章就介绍到这了,更多相关TypeScript遍历对象属性内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 微信小程序 template模板详解及实例代码

    微信小程序 template模板详解及实例代码

    这篇文章主要介绍了微信小程序 template模板详解及实例代码的相关资料,需要的朋友可以参考下
    2017-03-03
  • 关于Javascript闭包与应用的详解

    关于Javascript闭包与应用的详解

    这篇文章主要介绍了关于Javascript闭包与应用的详解,文中有非常详细的代码示例.对正在学习js的伙伴们有很好的帮助,需要的朋友可以参考下
    2021-04-04
  • lodash里的toLength和toPairs方法详解

    lodash里的toLength和toPairs方法详解

    这篇文章主要为大家介绍了lodash里的toLength和toPairs方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • JavaScript实现一键复制内容剪贴板

    JavaScript实现一键复制内容剪贴板

    这篇文章主要为大家介绍了JavaScript实现一键复制内容,document.execCommand原生JS设置剪贴板的实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • 一篇文章学会jsBridge的运行机制

    一篇文章学会jsBridge的运行机制

    JSBridge是一座用JavaScript搭建起来的桥,搭建这座桥的目的也很简单,让native可以调用web的js代码,让web可以 “调用” 原生的代码。本文主要通过分析源码讲解jsBridge的运行机制,感兴趣的朋友一起来看看吧
    2021-09-09
  • JS实用技巧实现loading加载示例详解

    JS实用技巧实现loading加载示例详解

    这篇文章主要为大家介绍了JS实用技巧实现loading加载示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • 微信小程序 前端源码逻辑和工作流详解

    微信小程序 前端源码逻辑和工作流详解

    这篇文章主要介绍了微信小程序 前端源码逻辑和工作流详解的相关资料,需要的朋友可以参考下
    2016-10-10
  • JavaScript 键盘事件的处理及属性详解

    JavaScript 键盘事件的处理及属性详解

    这篇文章主要为大家介绍了JavaScript 键盘事件的处理及属性详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • autojs长宽不定的图片在正方形图片居中实现详解

    autojs长宽不定的图片在正方形图片居中实现详解

    这篇文章主要为大家介绍了autojs长宽不定的图片在正方形图片居中实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • 详解微信小程序 相对定位和绝对定位

    详解微信小程序 相对定位和绝对定位

    这篇文章主要介绍了详解微信小程序 相对定位和绝对定位的相关资料,需要的朋友可以参考下
    2017-05-05

最新评论