TypeScript声明合并如何实现,有哪些简单的实例
Admin 2022-08-12 群英技术资讯 1342 次浏览
在实际应用中,我们有时候会遇到“TypeScript声明合并如何实现,有哪些简单的实例”这样的问题,我们该怎样来处理呢?下文给大家介绍了解决方法,希望这篇“TypeScript声明合并如何实现,有哪些简单的实例”文章能帮助大家解决问题。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));
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();
注意点: 类必须定义在命名空间的前面
会将命名空间中导出的方法作为一个静态方法合并到类中
class Person {
say():void{
console.log('hello world');
}
}
namespace Person{
export const hi = ():void=>{
console.log('hi');
}
}
console.dir(Person);
注意点: 函数必须定义在命名空间的前面
function getCounter() {
getCounter.count++;
console.log(getCounter.count);
}
namespace getCounter{
export let count:number = 0;
}
注意点: 没有先后顺序的要求
enum Gender {
Male,
Female
}
namespace Gender{
export const Yao:number = 666;
}
console.log(Gender);
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
js如何查找字符串的最长单词?这篇文章给大家分享是关于基于Free Code Camp基本算法脚本来查找字符串的最长单词,本文会介绍三种方法,是小编比较推荐的,有需要的朋友可以看一看。
基于JS怎样写个动态的旋转风车?有不少朋友对此感兴趣,下面小编给大家整理和分享了相关知识和资料,易于大家学习和理解,有需要的朋友可以借鉴参考,下面我们一起来了解一下吧。
检查nodejs是否安装成功的方法:1、打开“开始”菜单,在程序列表中找到node.js目录及程序,则证明安装成功;2、在cmd命令行中执行“node -v”命令,显示node版本,则证明安装成功。
这篇文章主要介绍了详解Typescript里的This的使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
文本主要给大家介绍的是关于js中promise用法,有promise的概念、promise的创建、promise的优势等等。小编觉得是比较实用的,因此分享给大家作参考。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008