当前位置: 首页 > news >正文

太原网站建设外包深圳服装设计学院

太原网站建设外包,深圳服装设计学院,上海企业服务云电话,超炫酷的网站TypeScript 怎么去查找类型定义的?类型文件分类第三方库的类型自定义类型结论类型文件分类 我们项目中的类型文件分为两种:一类是第三方库的类型,一类是在项目中的自定义类型。 第三方库的类型 (1)Jquery&#xff1…

TypeScript 怎么去查找类型定义的?

  • 类型文件分类
    • 第三方库的类型
    • 自定义类型
    • 结论

类型文件分类

我们项目中的类型文件分为两种:一类是第三方库的类型,一类是在项目中的自定义类型。

第三方库的类型

(1)Jquery:这是一个使用js写的库而不是ts。所以我们在ts中使用jquery是没有类型提示的。所以需要下载该库的一个类型包@types/jquery。
(2)react-use:这是一个用ts写的一个库,该库的package.json中含有types字段,即类型文件的入口。所以不用下载类型包。

自定义类型

针对没有类型的某些字段或者库,一般我们会在项目根目录创建 *.d.ts为其声明类型(全局库)。或者我们会在我么的ts、tsx文件中导出某种类型(模块化库)。

结论

那既然定义了这么多类型,ts编译器是如何找到它们的呢?

  1. 首先要说的是其实第三方库的类型查找的规则和 node 的包查找是类似的,首先会在当前文件夹找 node_modules,在他下面递归的去查找,如果找不到就会去上层的目录找到 node_modules 目录,再递归查找,直到根目录。
    (1)拿Jquery来说,ts编译器会在当前文件夹下的node_modules中找到Jquery,然后在package。json查找 types 属性发现没有。说明这是个js库。然后就去@types下面去找Jquery的类型定义。在package.json中发现有types属性,说明这个文件就是 jquery 类型定义的入口。
    (2)拿react-use来说,它是ts写的库,那么这个库的package.json中就含有types属性,就不需要类型包了。
  2. 之所以ts编译器会从@types下去找类型包,是tsconfig起了作用。tsconfig下有两个属性typeRoots 、types,它们的作用是啥?typeRoots 默认指向 node_modules/@types,这也就说明了为什么 ts 会去 @types 下面去找类型定义文件,既然这样说明我们也可以手动去调整 ts 的查找路径,比如我们本地用 ts 开发了一个通用的组件库,他的类型定义文件保存在 typings 目录下,那我们可以这么修改:
 "typeRoots": ["node_modules/@types","./typings"]

如果不希望自动引入 typeRoots 指定路径下的所有声明模块,那可以使用 types 指定自动引入哪些模块,比如:

"types" : ["node", "lodash", "express"]

那么就只会引入 node 、lodash、express 这三个声明模块,其它的声明模块则不会被自动引入

  1. 接着说files、include和exclude这三个属性是控制着 ts 编译器的编译范围,他们各自的特点如下:
    files 是一个数组,数组的元素可以是相对路径和绝对路径
    inclue 和 exclude 属性是一个数组,但是组的元素类似 glob 的文件模式,比如*、?、**/这种通配符的形式
    如果同时设置了files和include,那么编译器会把两者指定的文件引入,而 exclude 只会对 include 有效,对 files是无效的,即files指定的文件如果同时被 exclude 排除,那么该文件仍然会被编译器引入。
http://www.yayakq.cn/news/147876/

相关文章:

  • 个人备案能公司网站中牟网络推广公司
  • 定制网站建设服务商做推广效果哪个网站好
  • 宝安的医院网站建设免飞网站
  • 网站顶部小图标怎么做dreamviewer做网站
  • 外包网络推广公司推广网站个人网页制作教程与步骤
  • 西安电商网站制作wordpress不同分类文章不同模板
  • 凡科免费做网站莱芜做网站建设的公司
  • 重庆建设工程信息查询北京网站快速优化排名
  • 中国工程建设造价管理协会网站360路由器做网站
  • 深圳网站优化技巧廊坊网站制作网站
  • 做地方生活网站wordpress模板编辑
  • 怎么在网站后台做图片新闻成都广告公司简介
  • 网站建设与管理2018能用VUE做网站
  • 广东手机网站建设高平做网站
  • 注册网站的流程贸易公司网站案例
  • 如何找网站做推广wordpress很卡
  • 浏览器怎么设置不拦截任何网站装修公司加盟好还是自己开
  • 网站忧化工作怎么样网站建设的主要职责
  • 自己做网站如何赚钱在线教育网站开发实例
  • 自己做网站能赚钱乐清网站建设乐清
  • 阿里云怎么做静态网站国外虚拟主机wordpress
  • 昆山网站建设ikelv网站制作公司 深圳
  • 凡科建站自助建站平台龙岩seo培训
  • 完整的网站开发流程采集文章留在网站
  • 怎样做自己的网站钻钱设计师必备的软件
  • 网站目录权限设置设计公司网站设计报价明细表
  • 怎么做域名网站wordpress 论坛主题
  • 如何自己买域做网站wordpress 登录流程
  • 网站将要准备建设的内容搭建购物商城
  • 做淘宝客网站哪个好中国万网是干什么的