学习typescript(一)
环境
必装软件
- node,推荐 node 8.0
- npm,推荐 npm 5.0
- git, 最新版
- vscode, 编绎器
必装包
- tsc:
npm install -g typescript
- typings:
npm install -g typings
- ts-node:
npm install -g ts-node
说明一下
- tsc 为 typescript 的编绎绎,它能把 typescript 编绎成 js。
- typings 为下截别人标好的类型说明。
- ts-node 为开发环境中不用编绎成 js 直接运行 typescript 环境。
如何使用
新项目,这里指的项目都使用typecript进行开发
- 新建文件夹:
mkdir ts-test && cd ts-test
。 - 初始化
node
项目:npm init
。 - 设置初始化 'tsc --init',会生成一个
tsconfig.json
文件,这个文件很重要,就是tsc
的配置文件,内容下面会说。 - 运行版本控制:'git init',
git add -A
,git commit -m "init"
。 - 新建一个文件
test.ts
文件
console.log('hello, world');
- 运行命令:
tsc test.ts
,编绎文件,生成文件会在当前文件夹生成test.js
。 - 运行命令:
node test.js
,你会看见hello, world
。
这样一个小小的环境就建起来了,现在我们考虑下优化一下它。
在项目中,要控制生成文件的目录
这个需要在tsconfig.json
中的compilerOption
中添加"outDir": "dist"
,然后运行命令:tsc
,tsc
会自动加载tsconfig.json
。这样就会在当前目录下生成dist/test.js
,如果不加这行运行命令,跟tsc test.ts
的效果是一致的。在项目中,会控制
.ts
文件的目录和不需要编绎文件的目录
如果,不设置这两个选项,运行tsc
命令后,当前所有文件夹下的文件,当你的node_modules
很大的时候,这样非常慢。因此需要指定需要的目录和不需要的目录,在tsconfig.json
中增加include
和exclude
选项,这两个选项为数组,如下:
"exclude": [
"node_modules/",
"dist/"
],
"include": [
"src/**/*.ts" // 这里 /**/的意思为任何一个子目录的 `*.ts` 文件
]
开发项目中编绎
.ts
文件太麻烦,能不能直接运行
现在就是ts-node
发挥作用的时候,简单的把node
换成ts-node
就可以了。例如:ts-node src/test2.ts
如何引用
npm
上面的库?
这里会有问题,node
中加载库的标准是cmd
, 实现是require
。这在ts
中不支持,解决这个问题有两个方案:
第一方案:
在项目中任何一个.ts
中增加如下语句:
declare function require(path: string): any;
这样你可以自由的使用 require
第二方案:
使用 ts
自已的导入库的语法。
import foo = require("foo");
注:
我是 cmd
的支持者,我认为 es6
中 import
不支持动态导入是一个大问题。
已有一个 js 项目,如何体验 typescript
主要解决问题,ts 与 js 的交互问题?
这是下篇文篇的想说的问题。
学习typescript(一)的更多相关文章
- 在WisOne平台上学习TypeScript
TypeScript是微软公司推出的开源的类型化脚本语言,目的是用于为弱类型的javaScript提供强类型的识别和感知功能,同时它提供了类.接口.继承等相关在javaScript中不容易实现的功能, ...
- 学习TypeScript,笔记一:TypeScript的简介与数据类型
该文章用于督促自己学习TypeScript,作为学笔记进行保存,如果有错误的地方欢迎指正 2019-03-27 16:50:03 一.什么是TypeScript? TypeScript是javasc ...
- 学习typescript(二)
学习typescript(二) ts 与 js 交互 ts 调用 js module使用 分为两种情况: ts 调用自己写的 js ts 调用别人写的 js 也就通过 npm 安装的 第一种情况处理如 ...
- 被迫开始学习Typescript —— interface
一开始以为,需要使用 class 来定义呢,学习之后才发现,一般都是使用 interface 来定义的. 这个嘛,倒是挺适合 js 环境的. 参考:https://typescript.bootcss ...
- 「非软文」零基础学习TypeScript(源码开源)
今天,这篇文章篇幅很短,主要开放我最近学习整理TypeScript源码. 源码地址 https://github.com/maomincoding/typeScript_study 更多内容请见原文, ...
- 跟着Vam一起学习Typescript(第一期)
一.安装环境与配置1.命令行安装 npm i -g typescript 2.快捷打开Vs Code编辑器 创建一个项目文件夹,在该文件夹下打开命令行工具,使用code .命令快速打开编辑器(如果计算 ...
- 学习TypeScript 笔记
TypeScript 什么是TypeScript TypeScript 是 JavaScript 的一个超集,支持 ECMAScript 6 标准. TypeScript 由微软开发的自由和开源的编程 ...
- 【One by one系列】一步步学习TypeScript
TypeScript Quick Start 1.TypeScript是什么? TypeScript是ES6的超集. TS>ES7>ES6>ES5 Vue3.0已经宣布要支持ts,至 ...
- 初步学习TypeScript
使用Visual Studio Code搭建TypeScript开发环境 1.TypeScript是干什么的 ? TypeScript是由微软Anders Hejlsberg(安德斯·海尔斯伯格,也是 ...
随机推荐
- css控制字符长度超出变成点点点显示(单行,多行)
css控制字符长度超出变成点点点显示 单行: width 必不可少 div{ width: 55%; text-overflow: ellipsis; overflow: hidden; white- ...
- P1115最大子段和
题目:https://www.luogu.org/problemnew/show/P1115 很简明的一道题: 这里用了递归分治,然而似乎还有更简单的做法(贪心). 代码如下: #include< ...
- JavaScript-Tool-导向:jquery.steps-un
ylbtech-JavaScript-Tool-导向:jquery.steps 1.返回顶部 2.返回顶部 3.返回顶部 4.返回顶部 5.返回顶部 0. http://www.jqu ...
- C语言--递归问题
1,一个经典的例子,理解递归过程的展开 #include<stdio.h> void func(int i){ ) func(i/); printf("%d",i) } ...
- 性能测试之Jmeter学习(二)
一.Jmeter的基本操作 1.添加|移除测试元件 2.加载和保存测试元件 3.配置测试对中的测试元件 4.保存测试计划 5.运行测试计划 6.终止测试 7.错误报告 二.Jmeter体系结构 注释: ...
- A. Launch of Collider (#363 Div.2)
A. Launch of Collider time limit per test 2 seconds memory limit per test 256 megabytes input standa ...
- TypeScript完全解读(26课时)_8.ES6精讲-ES6中的类(进阶)
8.TypeScript完全解读-ES6精讲-类(进阶) 在index.ts内引入 Food创建的实例赋值给Vegetabled这个原型对象,这样使用Vegetables创建实例的时候,就能继承到Fo ...
- 28.Docker介绍与目录
快速的部署和启动 docker的启动是毫秒级的.一分钟可移动几百个上千个docker的容器 docker和虚拟机的区别 虚拟机在里面独立运行完整的操作系统.资源上时间上都需要多. docker容器级别 ...
- Identity Server 4 原理和实战(完结)_Authorization Code Flow 实例
Code在Oauth2.0和OpenId Connect里面分别叫做不同的名字 OAuth只介绍了如何授权.没有介绍如何身份认证. OpenId Connect:既规定了怎么授权,也规定了怎么身份认证 ...
- C# 获取汉字的拼音首字母和全拼(含源码)
C# 获取汉字的拼音首字母 一种是把所有中文字符集合起来组成一个对照表:另一种是依照汉字在Unicode编码表中的排序来确定拼音的首字母.碰到多音字时就以常用的为准(第一种方法中可以自行更改,方法为手 ...