《TypeScript》入门与精通-(1),小白也能看明白

或者使用Vue的脚手架新创建一个Vue3+typescript的项目,在其public下的index.html引入上方的jquery的cdn

描述文件

==============================================================

我们将以.d.ts为结尾的文件称作为描述文件,至于前面的文字是什么无所谓,不管是a.d.ts还是jQuery.d.ts都可以,它的作用就是为js文件描述类型;

这个涉及到第一个知识点,关键字:declare,它代表是一个声明,声明后面为定义类型的代码的类型,下面看具体分析

定义全局变量


比如,我们现在在.ts文件中编写jquery代码

;$(function() {})();

这个一个jquery时代常见的立即执行函数的方法,如果我们直接在.ts中写,它会报错,它会提示你必须去@types中安装jq的类型,错误如下:

Cannot find name ‘$’. Do you need to install type definitions for jQuery? Try npm i @types/jquery and then add jquery to the types field in your tsconfig

实际上我们在types中没有jquery的类型,因此,为了使它能在.ts中正常运行,我们需要在.d.ts这个描述文件中为其做声明:

declare const $: (param: () => void) => void;

分析一下这个声明,做一个拆分,外层如下

$() // 这是一个jquery函数

对应的声明

$:()=>void

仔细看看,这个应该能理解,声明 这 是 一 个 函 数 , 并 且 它 没 有 返 回 值 , 之 后 再 看 参 数 , 这是一个函数,并且它没有返回值,之后再看参数, 这是一个函数,并且它没有返回值,之后再看参数,()里面嵌套了一个function() {},对应的声明里也要嵌套一个函数类型,很明显,function() {}是$()的参数,这个参数是一个函数,并且它也没有返回值,

// 因此在外层的声明里,添加一个参数,并为其设置函数类型且没有返回值

param: () => void

定义全局函数


就拿上面的例子

;$(function() {})();

这明显也是一个函数,我们也可以使用函数的方式做声明

declare function $(params: () => void): void;

经过上面的分析,这个应该能明白点了吧,声明了一个函数$,它没有返回值,因此是void,但它有一个参数,参数是一个函数,并且也没有返回值;

到这里,可能有熟悉jQuery的小伙伴会问,jQuery还有别的用法,比如,它可以选择某个节点,为其添加内容,代码如下

$(function() {

$(“body”).append(“

oliver
”)

});

如果是这种写法,还是会报错的,没错,这种写法还是会继续报错,原因是这种写法我们没有在.d.ts中定义,因此,为这种用法,我们要写一个类型描述

// 类型

declare function $(

params: string

): {

append: (params: string) => {};

};

这次$()的函数是一个字符串,然后它的返回值虽然不知道具体是什么,但是既然能用.append这种方式,那么至少代表它是一个对象,在js中只有对象才有.这个操作符,之后立马有一个append的方法,它有一个参数,是一个字符串;

到这里可以差不多能简单理解了吧,再来一个练习

$(function() {

$(“.tc-demo-container”).css(“background-color”, “yellow”);

});

这个如何编写它的类型文件,解答如下

interface jQueryIntance {

css: (paramA: string, paramB: string) => jQueryIntance;

}

declare function $(params: string): jQueryIntance;

这次,我们把类型单独抽离出来定义成了一个接口,并且接口上有一个名为css的属性,它的值是一个函数,它有两个参数,参数的类型都是字符串,并且实际上这个函数是有返回值的,我们知道它的返回值是一个jquery对象;

Interface改写

看到上面那个练习,是不是发现了另外一种写法,描述文件是可以使用接口来定义的,

// interface改写

interface jQueryIntance {

css: (paramA: string, paramB: string) => jQueryIntance;

append: (paramA: string) => jQueryIntance;

}

declare const $: jQueryIntance;

定义全局对象


上面两种其实都是在介绍定义函数,那么对象怎么定义,还是拿jQuey举例,我们都知道,我们在使用$的时候,其实在jQuery内部会执行new $.fn.init这个方法,那么针对这个该怎么定义

// 待定义

new $.fn.init;

// 为了保证不冲突,可以使用namespace来框住

declare namespace $ {

namespace fn {

class init {}

}

}

再举一个实际项目中的例子,比如,我们写了一个类似于loadsh的工具函数util,我们挂载将其挂载到了window对象上,使用的时候会用以下的方式

util.add()

// 或者

window.util.add()

这个时候typescript就会报错,它会报window上不存在util这个东西,因此,我们需要在描述文件中对其做类型定义,我们可以这么写

declare interface Window {

util: {

add: () => void;

};

}

定义了一个Window(注意,Window是首字母大写的),它上面存在一个util的对象,这个对象上有一个add方法,这个方法没有参数,并且没有返回值;

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

由于篇幅限制,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!有需要的程序猿(媛)可以帮忙点赞+点击【学习资料】即可免费领取!

分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!**

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

由于篇幅限制,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!有需要的程序猿(媛)可以帮忙点赞+点击【学习资料】即可免费领取!

[外链图片转存中…(img-CjHKQCwy-1712272228824)]

[外链图片转存中…(img-qJnVNbis-1712272228825)]

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值