typescript-接口的基本使用(三)

上一节我们讲了可接口中可选属性的用法,那么现在想这样一个问题,小的时候,我们看超人,超人可以做任何事情。不仅限于帮助人,帮助动物,帮助植物.....因为这些种类都有不同的"属性",我们不可以局限于某个属性,那么,这里我们也是可以有办法的。

TypeScript 复制代码
interface IAnyObj {
    [prop: string]: any;
}

class SuperMan {
    public doAnyThing(anyObj: IAnyObj): void {
        console.log("超人做任何事情 ", anyObj);
    }
}

let superMan = new SuperMan();
superMan.doAnyThing({ age: 999 });
superMan.doAnyThing({ name: "任何人" });
superMan.doAnyThing([99, 55]);

tsc index.ts

在这里我们定义了IAnyObj的接口,这里的**[prop: string]: any;表示包含"任意字符串类型"的属性** 的事物,都可以传递到doAnyThing的方法中。最后的那个数组有点例外,其实访问的时候,他也会进行转换,把索引按照字符串来读取。其实这涉及到一个动态属性的问题。

比如传递过来的数据,你不确定这个数据都有哪些属性,那么就可以用下面的方法进行访问

TypeScript 复制代码
interface IAnyObj {
    [prop: string]: any;
}

class SuperMan {
    public doAnyThing(anyObj: IAnyObj): void {
        // console.log("超人做任何事情 ", anyObj);
        let keys = Object.keys(anyObj);
        if (keys.length) {
            for (let i = 0; i < keys.length; i++) {
                console.log(
                    "访问的属性 ",
                    keys[i],
                    "对应的值为 ",
                    anyObj[keys[i]]
                );
            }
        }
    }
}

let superMan = new SuperMan();
superMan.doAnyThing({ age: 999 });
superMan.doAnyThing({ name: "任何人" });
superMan.doAnyThing([99, 55]);
let arr = [99, 55];
console.log(arr["0"]);
相关推荐
菜鸟小芯16 分钟前
【GLM-5 陪练式前端新手入门】第一篇:从 GLM-5 提示到实践,完成前端入门第一步
前端·人工智能
木斯佳19 分钟前
前端八股文面经大全:字节跳动交易与广告前端一面(2026-2-10)·面经深度解析
前端
Highcharts.js36 分钟前
如何根据派生数据创建钟形曲线图表?highcharts正态分布曲线使用指南:从创建到设置一文搞定
开发语言·javascript·开发文档·正态分布·highcharts·图表类型·钟形图
a11177641 分钟前
纸张生成器(html开源)
前端·开源·html
心.c1 小时前
虚拟滚动列表
前端·javascript·vue.js·js
祯民1 小时前
《复合型 AI Agent 开发:从理论到实践》实体书上架
前端
NEXT061 小时前
深拷贝与浅拷贝的区别
前端·javascript·面试
不写八个1 小时前
PixiJS教程(一):快速搭建环境启动项目
前端·pixijs
PieroPc2 小时前
用html+css+js 写一个Docker 教程
javascript·css·docker·html
菜鸟小芯2 小时前
【GLM-5 陪练式前端新手入门】第二篇:CSS 让网页从 “能用” 变 “好看”
前端·css