Angular2管理外部类型定义和处理“Duplicate identifier” TypeScript错误

在学习angular2的时候,根据angular2中文网提供的quickstart作为种子项目。在安装完所有包并运行项目的时候,出现了满屏的编译错误:

error TS2300: Duplicate identifier

在这里就聊聊这个错误的原因和如何修复它。为了能更好的明白这个问题,我们先讨论TypeScript和Javascript,以及外部类型定义和@types之间的不同。

介绍

在深入之前,先说一下TypeScript的外部类型定义。
如果你比较熟悉TypeScript和JavaScript之间的区别,可以跳过这一部分。

TypeScript是静态类型语言,是JavaScript的超集。静态类型意思是我们所写的程序要经过一个编译的阶段,在这个阶段,编译器执行类型检查,在一定程度上核实正确性。例如:

// person-human.ts

class Person {
  talk() {
    // ...
  }
}

class Superhero extends Person {
  fly() {
    // ...
  }
}

let bar = new Person();

bar.fly();

如果我们编译上面的代码,TypeScript编译器会报错:

$ tsc person-human.ts
Property 'fly' does not exists on type 'Person'.

如果我们运行相应的JavaScript文件,得到错误:

$ node person-human.js
Uncaught TypeError: bar.fly is not a function

虽然上面的两种脚本都报错,但是tsc是在编译时间报的错,而node是在运行时间报的错。

编译时间的错误是容易被开发者处理的,因为错误是基于开发者的静态代码分析的。意味着,在用户使用代码前,编译器能够通知开发者可能的错误。

另一方面,我们使用JavaScript动态类型,我们不可能找出所有我们犯的错误。为动态类型语言的代码进行静态代码分析是很难的(几乎是不可能的),因此,代码发布到生产环境后,仍然没有找到可能存在的问题也是相当有可能的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值