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"]);
相关推荐
kyriewen1112 小时前
你点的“刷新”是假刷新?前端路由的瞒天过海术
开发语言·前端·javascript·ecmascript·html5
Timer@14 小时前
LangChain 教程 04|Agent 详解:让 AI 学会“自己干活“
javascript·人工智能·langchain
阿珊和她的猫14 小时前
TypeScript中的never类型: 深入理解never类型的使用场景和特点
javascript·typescript·状态模式
skywalk816314 小时前
Kotti Next的tinyfrontend前端模仿Kotti 首页布局还是不太好看,感觉比Kotti差一点
前端
RopenYuan16 小时前
FastAPI -API Router的应用
前端·网络·python
走粥17 小时前
clsx和twMerge解决CSS类名冲突问题
前端·css
Purgatory00117 小时前
layui select重新渲染
前端·layui
weixin1997010801618 小时前
《中国供应商商品详情页前端性能优化实战》
前端·性能优化
九皇叔叔18 小时前
003-SpringSecurity-Demo 统一响应类
java·javascript·spring·springsecurity