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"]);
相关推荐
橙子家3 小时前
浏览器缓存之【基础键值存储】:Local storage 和 Session storage
前端
星星在线5 小时前
MusicFree:一个「All in One」的个人音乐服务器,让听歌回归简单
前端·后端
IT_陈寒6 小时前
Redis的SETNX并发问题让我加了三天班
前端·人工智能·后端
demo007x6 小时前
Docling 文档转换以及技术架构分析
前端·后端·程序员
京东云开发者7 小时前
京东市民服务又“上新”!这次是黑龙江“龙易办”
前端
袋鱼不重8 小时前
我的神奇同事,AI 用多了居然写了个 Open In Codex
前端·后端·ai编程
竹林8188 小时前
Web3表单签名验证:我用 wagmi 和 ethers 给 DApp 加了一个“免密登录”,踩坑记录全在这了
javascript
用户6990304848758 小时前
try catch使用场景 处理同步代码错误兼容用的
javascript·uni-app
雪碧聊技术8 小时前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript
Fireworks8 小时前
深入vue3源码解读 -- 1、响应式的基础概念
前端