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"]);
相关推荐
weixin_4434785112 分钟前
flutter学习之状态管理相关组件
javascript·学习·flutter
掘金安东尼36 分钟前
⏰前端周刊第 456 期(v2026.3.15)
前端·javascript·面试
还是大剑师兰特36 分钟前
Vue3 通用可复用动态插槽组件(终极版)
前端·javascript·vue.js
nibabaoo1 小时前
前端开发攻略---在 Vue 3 项目中使用 vue-i18n 实现国际化多语言
前端·javascript·国际化·i18n·vue3
qq_437100661 小时前
ElasticSearch相关记录
大数据·前端·javascript·elasticsearch·全文检索
CHU7290351 小时前
剧本杀组车约玩小程序前端功能版块设计及玩法介绍
前端·小程序
清空mega1 小时前
《Vue3 模板进阶:class/style 绑定、事件对象、修饰符、表单处理与高频易错点》
前端·javascript·vue.js
还是大剑师兰特1 小时前
Vue3 插槽完整实战(具名插槽 + 动态插槽)
前端·javascript·vue.js
fei_sun1 小时前
Vue+SpingBoot+MyBaits框架
前端·javascript·vue.js
爱吃鱼的锅包肉1 小时前
利用css+js实现一个图片随鼠标滑动裁剪的功能
前端·javascript·css·计算机外设