一、問題
比如下面的代碼:
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]) //不報錯 } }