TypeScript聲明合並的實現
1.接口合並
interface TestInterface { name:string; } interface TestInterface { age:number; } //相當於下面 interface TestInterface { name:string; age:number; } class Person implements TestInterface{ name:string; age:number; }
1.1同名接口如果屬性名相同, 那麼屬性類型必須一致
interface TestInterface { name:string; } interface TestInterface { name:number;//報錯 }
1.2同名接口如果出現同名函數, 那麼就會成為一個函數的重載
interface TestInterface { getValue(value:number):number; } interface TestInterface { getValue(value:string):number; } let obj:TestInterface = { getValue(value:any):number{ if(typeof value === 'string'){ return value.length; }else{ return value.toFixed(); } } } console.log(obj.getValue("abcdef")); console.log(obj.getValue(3.14));
2.命名空間
namespace Validation{ export let name:string = 'lnj'; } namespace Validation{ export let age:number = 18; } console.log(Validation.name); console.log(Validation.age);
2.1同名的命名空間中不能出現同名的變量,方法等
namespace Validation{ export let name:string = 'lnj'; export let say = ()=> "abc"; } namespace Validation{ export let name:string = 'zs';//報錯 export let say = ()=> "abc";//報錯 }
2.2同名的命名空間中其它命名空間沒有通過export導出的內容是獲取不到的
namespace Validation{ let name:string = 'lnj';//輸出name = 獲取不到name // export let name:string = 'lnj'; 輸出name =lnj } namespace Validation{ export let say = ()=> { console.log(`name = ${name}`); }; } Validation.say();
3.命名空間和類合並
註意點: 類必須定義在命名空間的前面
會將命名空間中導出的方法作為一個靜態方法合並到類中
class Person { say():void{ console.log('hello world'); } } namespace Person{ export const hi = ():void=>{ console.log('hi'); } } console.dir(Person);
4.命名空間和函數合並
註意點: 函數必須定義在命名空間的前面
function getCounter() { getCounter.count++; console.log(getCounter.count); } namespace getCounter{ export let count:number = 0; }
5.命名空間和枚舉合並
註意點: 沒有先後順序的要求
enum Gender { Male, Female } namespace Gender{ export const Yao:number = 666; } console.log(Gender);
到此這篇關於TypeScript聲明合並的實現的文章就介紹到這瞭,更多相關TypeScript聲明合並內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- TypeScript基本類型之typeof和keyof詳解
- typescript快速上手的基礎知識篇
- TypeScript保姆級基礎教程
- TypeScript聲明文件的語法與場景詳解
- 分享Typescript的13個基礎語法