TypeScript遍歷對象屬性的問題
更新時間:2021年11月11日 09:48:05 作者:guo&qi
這篇文章主要介紹了TypeScript遍歷對象屬性的問題,文章圍繞TypeScript遍歷對象屬性的相關(guān)資料展開詳細內(nèi)容,需要的朋友可以參考一下
一、問題
比如下面的代碼:
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]) //不報錯 } }
到此這篇關(guān)于TypeScript遍歷對象屬性的問題的文章就介紹到這了,更多相關(guān)TypeScript遍歷對象屬性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS觸摸屏網(wǎng)頁版仿app彈窗型滾動列表選擇器/日期選擇器
這篇文章主要介紹了觸摸屏網(wǎng)頁版仿app彈窗型滾動列表選擇器/日期選擇器的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-10-10PHP:微信小程序 微信支付服務(wù)端集成實例詳解及源碼下載
這篇文章主要介紹了微信小程序 微信支付服務(wù)端集成實例詳解及源碼下載的相關(guān)資料,需要的朋友可以參考下2017-01-01關(guān)于Javascript閉包與應(yīng)用的詳解
這篇文章主要介紹了關(guān)于Javascript閉包與應(yīng)用的詳解,文中有非常詳細的代碼示例.對正在學習js的伙伴們有很好的幫助,需要的朋友可以參考下2021-04-04