总结TypeScript 的一些知识点:TypeScript 声明文件

简介: 程序来输出 "Hello World" :当然,很多流行的第三方库的声明文件不需要我们定义了,比如 jQuery 已经有人帮我们定义好

引言


程序来输出 "Hello World" :当然,很多流行的第三方库的声明文件不需要我们定义了,比如 jQuery 已经有人帮我们定义好


TypeScript 程序由以下几个部分组成:


模块

函数

变量

语句和表达式

注释


第一个 TypeScript 程序


我们可以使用以下 TypeScript 程序来输出 "Hello World" :

Runoob.ts 文件代码:
const hello : string = "Hello World!"
console.log(hello)


以上代码首先通过 tsc 命令编译:

tsc Runoob.ts

得到如下 js 代码:

Runoob.js 文件代码:
var hello = "Hello World!";
console.log(hello);


最后我们使用 node 命令来执行该 js 代码。

$ node Runoob.js
Hello World


整个流程如下图所示:


我们可以同时编译多个 ts 文件:

tsc file1.ts file2.ts file3.ts


tsc 常用编译参数如下表所示:

1706876874627.png


1706876874627.png1706876874627.png

TypeScript 保留关键字


TypeScript 保留关键字如下表所示:

1706877053780.png

空白和换行


TypeScript 会忽略程序中出现的空格、制表符和换行符。


空格、制表符通常用来缩进代码,使代码易于阅读和理解。


TypeScript 区分大小写


TypeScript 区分大写和小写字符。


分号是可选的


每行指令都是一段语句,你可以使用分号或不使用, 分号在 TypeScript 中是可选的,建议使用。


以下代码都是合法的:

console.log("Runoob")
console.log("Google");


如果语句写在同一行则一定需要使用分号来分隔,否则会报错,如:

console.log("Runoob");console.log("Google");


TypeScript 注释


注释是一个良好的习惯,虽然很多程序员讨厌注释,但还是建议你在每段代码写上文字说明。


注释可以提高程序的可读性。


注释可以包含有关程序一些信息,如代码的作者,有关函数的说明等。


编译器会忽略注释。


TypeScript 支持两种类型的注释

单行注释 ( // ) − 在 // 后面的文字都是注释内容。


多行注释 (/* */) − 这种注释可以跨越多行。


注释实例:

// 这是一个单行注释
/* 
 这是一个多行注释 
 这是一个多行注释 
 这是一个多行注释 
*/


TypeScript 与面向对象


面向对象是一种对现实世界理解和抽象的方法。


TypeScript 是一种面向对象的编程语言。


面向对象主要有两个概念:对象和类。


对象 :对象是类的一个实例(对象不是找个女朋友),有状态和行为。例如,一条狗是一个对象,它的状态有:颜色、名字、品种;行为有:摇尾巴、叫、吃等。

类:类是一个模板,它描述一类对象的行为和状态。

方法:方法是类的操作的实现步骤。

下图中 girl、boy 为类,而具体的每个人为该类的对象:


TypeScript 面向对象编程实例:

class Site { 
   name():void { 
      console.log("Runoob") 
   } 
} 
var obj = new Site(); 
obj.name();


以上实例定义了一个类 Site,该类有一个方法 name(),该方法在终端上输出字符串 Runoob。


new 关键字创建类的对象,该对象调用方法 name()。


编译后生成的 JavaScript 代码如下:

var Site = /** @class */ (function () {
    function Site() {
    }
    Site.prototype.name = function () {
        console.log("Runoob");
    };
    return Site;
}());
var obj = new Site();
obj.name();
TypeScript 作为 Jav

aScript 的超集,在开发过程中不可避免要引用其他第三方的 JavaScript 的库。虽然通过直接引用可以调用库的类和方法,但是却无法使用TypeScript 诸如类型检查等特性功能。为了解决这个问题,需要将这些库里的函数和方法体去掉后只保留导出类型声明,而产生了一个描述 JavaScript 库和模块信息的声明文件。通过引用这个声明文件,就可以借用 TypeScript 的各种特性来使用库文件了。


假如我们想使用第三方库,比如 jQuery,我们通常这样获取一个 id 是 foo 的元素:

$('#foo');
// 或
jQuery('#foo');


但是在 TypeScript 中,我们并不知道 $ 或 jQuery 是什么东西:

jQuery('#foo');
// index.ts(1,1): error TS2304: Cannot find name 'jQuery'.


这时,我们需要使用 declare 关键字来定义它的类型,帮助 TypeScript 判断我们传入的参数类型对不对:

declare var jQuery: (selector: string) => any;
jQuery('#foo');


declare 定义的类型只会用于编译时的检查,编译结果中会被删除。


上例的编译结果是:

jQuery('#foo');


声明文件

声明文件以 .d.ts 为后缀,例如:

kxdang.d.ts


声明文件或模块的语法格式如下:

declare module Module_Name {
}


TypeScript 引入声明文件语法格式:

/// <reference path = " kxdang.d.ts" />


当然,很多流行的第三方库的声明文件不需要我们定义了,比如 jQuery 已经有人帮我们定义好了:jQuery in DefinitelyTyped。


实例

以下定义一个第三方库来演示:

CalcThirdPartyJsLib.js 文件代码:
var Runoob;  
(function(Runoob) {
    var Calc = (function () { 
        function Calc() { 
        } 
    })
    Calc.prototype.doSum = function (limit) {
        var sum = 0; 
        for (var i = 0; i <= limit; i++) { 
            sum = sum + i; 
        }
        return sum; 
    }
    Runoob.Calc = Calc; 
    return Calc; 
})(Runoob || (Runoob = {})); 
var test = new Runoob.Calc();


如果我们想在 TypeScript 中引用上面的代码,则需要设置声明文件 Calc.d.ts,代码如下:

Calc.d.ts 文件代码:

declare module Runoob { 
   export class Calc { 
      doSum(limit:number) : number; 
   }
}


声明文件不包含实现,它只是类型声明,把声明文件加入到 TypeScript 中:

CalcTest.ts 文件代码:

/// <reference path = "Calc.d.ts" /> 
var obj = new Runoob.Calc(); 
// obj.doSum("Hello"); // 编译错误
console.log(obj.doSum(10));


下面这行导致编译错误,因为我们需要传入数字参数:

obj.doSum("Hello");


使用 tsc 命令来编译以上代码文件:

tsc CalcTest.ts


生成的 JavaScript 代码如下:

CalcTest.js 文件代码:
/// <reference path = "Calc.d.ts" /> 
var obj = new Runoob.Calc();
//obj.doSum("Hello"); // 编译错误
console.log(obj.doSum(10));


最后我们编写一个 kxdang.html 文件,引入 CalcTest.js 文件及第三方库 CalcThirdPartyJsLib.js:


实例

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(kxdang.com)</title>
<script src = "CalcThirdPartyJsLib.js"></script> 
<script src = "CalcTest.js"></script> 
</head>
<body>
    <h1>声明文件测试</h1>
    <p>菜鸟测试一下。</p>
</body>
</html>


浏览器打开该文件输出结果如下:


总结


Vue 进阶系列教程将在本号持续发布,一起查漏补缺学个痛快!若您有遇到其它相关问题,非常欢迎在评论中留言讨论,达到帮助更多人的目的。若感本文对您有所帮助请点个赞吧!


相关文章
|
2月前
|
JavaScript 前端开发 安全
TypeScript基础知识点
TypeScript基础知识点
51 0
|
2月前
|
JavaScript 前端开发
总结TypeScript 的一些知识点:TypeScript Array(数组)(下)
一个数组的元素可以是另外一个数组,这样就构成了多维数组(Multi-dimensional Array)。
|
2月前
|
存储 JavaScript 前端开发
总结TypeScript 的一些知识点:TypeScript Array(数组)(上)
数组对象是使用单独的变量名来存储一系列的值。
|
2月前
|
JavaScript 前端开发 编译器
TypeScript【泛型1、泛型2、声明合并、命名空间 、模块1、模块2、声明文件简介】(五)-全面详解(学习总结---从入门到深化)
TypeScript【泛型1、泛型2、声明合并、命名空间 、模块1、模块2、声明文件简介】(五)-全面详解(学习总结---从入门到深化)
91 0
|
2月前
|
编解码 JavaScript 前端开发
TypeScript【第三方声明文件、自定义声明文件、tsconfig.json文件简介、tsconfig.json 文件结构与配置】(六)-全面详解(学习总结---从入门到深化)
TypeScript【第三方声明文件、自定义声明文件、tsconfig.json文件简介、tsconfig.json 文件结构与配置】(六)-全面详解(学习总结---从入门到深化)
144 0
|
24天前
|
JavaScript 前端开发 IDE
TypeScript中的声明文件(.d.ts):扩展类型系统
TypeScript的`.d.ts`声明文件为JS库提供类型信息,增强IDE支持,如自动完成和类型检查。通过声明合并,可在全局作用域定义类型。示例包括为`my-library`创建声明模块,导出函数和接口。声明文件通常存于`@types`或指定`typeRoots`。用于旧JS代码的类型注解,如`myGlobalObject`。学习更多,参阅TypeScript官方文档。分享你的TS声明文件经验!
|
9月前
|
JavaScript 前端开发
软件开发入门教程网之TypeScript 声明文件
软件开发入门教程网之TypeScript 声明文件
|
2月前
|
JavaScript 前端开发 编译器
如何编译Typescript文件?
如何编译Typescript文件?
|
2月前
|
JavaScript 前端开发 编译器
TypeScript【泛型1、泛型2、声明合并、命名空间 、模块1、模块2、声明文件简介】(五)-全面详解(学习总结---从入门到深化)(下)
TypeScript【泛型1、泛型2、声明合并、命名空间 、模块1、模块2、声明文件简介】(五)-全面详解(学习总结---从入门到深化)
40 0
TypeScript【泛型1、泛型2、声明合并、命名空间 、模块1、模块2、声明文件简介】(五)-全面详解(学习总结---从入门到深化)(下)
|
2月前
|
JavaScript
TypeScript【泛型1、泛型2、声明合并、命名空间 、模块1、模块2、声明文件简介】(五)-全面详解(学习总结---从入门到深化)(上)
TypeScript【泛型1、泛型2、声明合并、命名空间 、模块1、模块2、声明文件简介】(五)-全面详解(学习总结---从入门到深化)
51 0