您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
免费发信息

Js与TypeScript联系

2024/4/26 2:24:15发布9次查看
这次给大家带来js与typescript联系,js与typescript使用的注意事项有哪些,下面就是实战案例,一起来看一下。
前话
typescript是javascript类型的超集,这是typescript的文档介绍的一句话,那么他们存在联系呢?
我的理解是,typescript在javascript基础上引入强类型语言的特性。开发者使用typescript语法进行编程开发,最终通过转换工具将typescript转换成javascript。
使用typescript能够避免在原生javascript上开发所带来的弱类型语言的坑。(我该输入啥?调用后返回啥?哎还是看看源码吧。。。)
嗯!很好,强类型的javascript,挺好的。但是,我舍不得那npm里众多库无微不至的人文关怀啊o(tヘto)
别怕,现在很多库已经悄悄地支持typescript,就算它无心支持,也有无私奉献的大佬们悄悄地帮这些库支持typescript了
这就是引出了本文的主题,typescript的声明文件,我认为它是javascript库类似c语言的头文件,它的存在便是帮助typescript引入javascript库
什么是声明文件?
和 c/c++ 的 *.h 头文件(header files)非常相似:当你在 c/c++ 程序中引用了一个第三方库(.lib/.dll/.so/.a/.la)时,c/c++ 编译器无法自动地识别库内导出名称和函数类型签名等,这就需要使用头文件进行接口声明了。
同理地,typescript 的声明文件是一个以 .d.ts 为后缀的 typescript 代码文件,但它的作用是描述一个 javascript 模块(广义上的)内所有导出接口的类型信息。
关于typescript声明文件的写法和规范请参考参考如下官方文档和优秀博文:
https://www.tslang.cn/docs/handbook/declaration-files/introduction.html
http://www.jb51.net/article/138217.htm
根据官方文档介绍,有以下两个捆绑方式:
与你的npm包捆绑在一起
发布到npm上的@types organization
与npm包捆绑一起就是前面说的,开发者在ts项目中npm install一个库并在代码文件中import后直接即可使用。
当部分库官方不维护的时候,就可以通过第二个方式,在npm install一个库后,再执行 npm install @types/库名 安装库的声明文件即可使用。其原理是typescript在2.0版本之后,当你import 一个库的时候,当他在配置的include路径中未找到指定的库,就会在node_modules的@types中寻找该库。
一般来说,官方推荐第一种方式书写发布声明文件,下面我直接用例子来展示第一种捆绑方式吧。
例子
首先初始化typescript项目,目录结构如下:
tsconfig.json配置如下:
{ compileroptions: { target: es5, /* specify ecmascript target version: 'es3' (default), 'es5', 'es2015', 'es2016', 'es2017', or 'esnext'. */ module: commonjs, /* specify module code generation: 'none', commonjs', 'amd', 'system', 'umd', 'es2015', or 'esnext'. */ allowjs: true, outdir: ./dist, /* redirect output structure to the directory. */ /* allow javascript files to be compiled. */ strict: true /* enable all strict type-checking options. */ }, include: [ src/**/* ]}
可以看到,我写了个模块 a ,并且给它捆绑了声明文件,模块 a ,即 src/a/index.js 内容如下:
const name = 'a';let call = (who) => { console.log('hello ' + who + '! i am ' + name);}export default { call}
其声明文件即 src/a/index.d.ts 内容如下:
declare namespace a { function call(who: string): void;}export default a;
这时,我们便可以在入口文件 src/index.ts 引入 a 模块:
import a from './a';a.call('pwcong');
命令行执行 tsc 后即可在目录 dist 中生成js代码:
执行命令 node ./dist/index.js 可以得到相应正确的输出。
我们再模拟导入发布后的npm库,在 node_modules 目录下创建目录 b ,并初始化node项目,这时目录结构如下:
其中 node_modules/b/types/package.json 内容如下:
{ name: b, version: 1.0.0, main: ./src/index.js, types: ./types/index.d.ts}
node_modules/b/src/index.js 内容如下:
const name = 'b';let call = (who) => { console.log('hello ' + who + '! i am ' + name);}module.exports = { call}
声明文件 node_modules/b/types/index.d.ts 内容如下:
declare namespace b { function call(who: string): void;}export = b;
这时,我们修改 src/index.ts :
import a from './a';a.call('pwcong');import b = require('b');b.call('pwcong');
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
redux-thunk实战项目案例详解
如何使用angular数据绑定机制
以上就是js与typescript联系的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录