首先先明确,用node+ts的目的,为什么不ng+ts。这一点后面还会反复提醒自己 node毕竟不是ng。

用node的理由:

处理js,在后端操纵dom,读写类html格式的东西,比直接用py的后端更舒服。

着眼点还是后端数据处理,作为类似单机版数据库的后台进程db_master(RESTful API等于 数据库的CRUD)。

不需要写界面,不需要web component这些。所以用ts,不意味着,到处都是class。仍然是data居多,function居多。

用ts的理由:

主要理由:给了增加类型注解的选择权,export方式也更贴近es6标准。

不太成立的理由:自己毕竟写过了点ng。ts用着还可以,其实es6本身,经过2015 2016 2017,也很不错了。

用node+ts稍微写点东西,就发现

1 各种库必须自己知道选择,安装。

2 js语言太乱。编码风格,module居然好几套玩法,浏览器端的amd 服务器端的commonjs  es6 不要说,还有ts

而且package.json,tsconfig.json往往都要自己修改配置,要知道改这个(习惯cli接口,习惯命令行参数的,会好受些)。

现在就体会到py的好了:果然鱼最难感知的就是水的存在。

1 py有大而全的标准库,30多个主题,我写到今天也不敢保证都用过。保证了开箱即用,不需要这样自己东1个库,西1个库。即使py的标准库往往不是实际中最优的库,但是对上手来说,够用了。单元测试不用必须手动安装pytest,用自带的unittest就基本够用了。

总的感觉是pip库质量比npm高很多。node也就是flask一样的微框架而已。

2 py代码本身风格就很整齐。自从09年2/3代切换之后,就更没什么坑。

记录一些从py开发者角度看遇到的很别扭的坑。

1 @types

为了ts使用而 npm i @types/XXX,但这个并不能代替XXX本身的安装。

可以理解成@types只是为js库提供了index.d.ts 这样的带有类型注解的导出声明而已。如果js库类似于是.c的话,@types就类似于给加了一个.h文件。

不能代替.c本身。

所以用d3 npm i d3 @types/d3  都要装,其他库同理.

2 单元测试

要用到mocha和chai。

注意, 因为是用ts,所以在package.json里这样写:

"scripts": {
"build-ts": "tsc",
"start": "ts-node src/server.ts",
"start:dev": "nodemon",
"serve": "node dist/server.js",
"test": "mocha --require ts-node/register test/**/*.ts"
},

test得写成这样,注意还用到了ts-node。

测试用例在根目录的test路径下 .ts结尾 测试用例的例子:

import { expect } from 'chai';
import 'mocha'; import {helloworld} from '../src/a.ts'
describe('Hello function', () => {
  it('should return hello world', () => {
  const result = helloword();
  expect(result).to.equal('Hello World!');
});
})

然后是在vscode里file 首选项,键盘快捷方式里,搜索run test  找到运行全部测试用例。设置一个快捷键。我给了ctrl+alt+t

这样就可以单元测试了。

3node中module的导入

分为2种情况

3.1 第三方库

安装在node_modules里的那些。

因为我是用ts写,所以 npm i XXX @types/XXX 是可以的,

不过在node里用,还是有node版就直接装node版的 d3-node最省事

而且,在tsconfig,json里因为"module":是 "commonjs",

{
"compilerOptions": {
  "module": "commonjs",
}

所以,在ts文件里,也可以直接按node的commonjs的写法:

var d3 = require('d3');
这样用。
不必须import from,  node毕竟不是ng。

3.2自己写的代码库

又分好几种情况

服务器端用:

1ts写,供ts调用

其实反而和es6差不多,直接结尾export {}即可,最简单。

还可能将来复用到ng等等别的地方。

2 js写,commonjs方式,供ts调用

直接node的commonjs方式 文件结尾 module.exports = {XXX,}
如果只准备在node端用的代码,这样也够了,但不如1

3 es6写的js,供ts调用

这样的目的,是试图这个js库准备兼容浏览器和服务端,两边都使用。

如果js里是es6的写法 export {}   直接执行测试,会报错,SyntaxError: Unexpected token export

怎么都搞不定,还是看ts官网 Migrating from JavaScript

在tsconfig.json里加入

"compilerOptions": {
"module": "commonjs",
"resolveJsonModule": true,
"esModuleInterop": true,
"target": "es6",
"noImplicitAny": false,
"allowJs": true,
...
}

直接搞定。

原因:

如果没有这个选项,那么tsc遇到js时不处理,然后node用commonjs模块机制处理,那么目前就还不认识export关键字。所以报错了;

如果打开这个选项,tsc会去处理js文件,ts是认识exports关键字的,在别处 import from 就没事了。

——坑点:TM这个选项,还有很多别的选项,可能没列在默认的tsconfig.json里啊啊啊(tsconfig.json也许来自其他地方copy过来的,2333)。那么tsc是个超多选项的cli,那么多默认参数,新手不可能每个都知道。如果tsconfig.json写漏了就麻烦了。

4 noImplicitAny ,  true or false?

tsconfig.json里的noImplicitAny可以控制:
如果true,函数的形参必须带类型,如果叫不出class名的js对象,那就得any,比如(d:any)=>{}
如果false,函数的样子更像js  (d)=>{}
 
到底用不用强制写class?
 
如果false,而且确实什么类型注解都不写,那么用ts的意思其实不大了,直接写原生的es6就可以了,推荐阮一峰老师的《ES6标准入门 第3版》
但是true的话,又到处都是any尤其是(d:any)=>{} ,确实很丑,很没有必要,ts的类型声明只是注解,毕竟还是要转成js执行的。ts也毕竟不是java,我也不是java程序员。
而且,现在写了这么久的代码,自己的感觉不是“一切都是类”,“一切都是函数”,“一切都是文件”,而是“该是class的才是class,该是function的,就是function”。
 
一个工程就好像一支军队,成军之法:
既可以是正规军的“有状态的部队”写法:namespace下辖class,class下辖method
也可以是扁平化,“无状态的分队”写法: module辖var,function
 
我的ts,不能给搞成完全没有类型的史前js;也不能矫枉过正,强制搞成了java,搞得一切必须弄成class,层层的封装。
 
所以,最佳选择是获得更多的选择权:
保留不加类型注解的权利,也要获得加类型注解的权利。
 因此
1 这个选项设置为false。自定义的ts类加注解(写node毕竟不是用ng写web component,没有那么多class),string number这样的基本类型加注解。
2 其他的地方不加类型注解,特别是d3 数据绑定时等等常用的(d)=>{}写法,继续保留不加注解的写法。
 这样用起来,更像py,哈哈哈

node+ts的心得与坑的更多相关文章

  1. ubuntu下搭建node server的几个坑

    [ubuntu下搭建node server的几个坑] 1.环境变量 process.env.PORT需要使用 export PORT=80设置 windows下是set PORT=80 2.命令连结 ...

  2. Node.js学习心得

    最近花了三四周的时间学习了Node.js ,感觉Node.js在学习过程中和我大学所学的专业方向.NET在学习方法上有好多的相似之处,下面就将我学习的心得体会以及参考的资料总结归纳如下,希望对于刚入门 ...

  3. Win7 node多版本管理gnvm采坑记录

    采坑描述:下载新node版本及切换node失败 解决:1.要用管理员权限启动cmd:2.确保node是空闲的 Gnvm下载地址: 32-bit | 64-bit Github 1.下载之后为 得到一个 ...

  4. vue+node+mongoose踩过的坑

    1.当你在cmd中输入npm run dev的时候,出现这种错误 很有可能是目前的端口被占用了,可以把所有可能用到这个端口号的应用关闭或者你直接改一个新的端口号 修改端口的方法:新打开一个cmd,然后 ...

  5. node+express第一次实战踩坑记录

    读万卷书不如行万里路,必须实践出真理! 问题1:项目结构该搭建成什么样? 我一个node.js小白,完全没有想法!再见! 找找别人的项目看看别人放的什么项目结构,再结合自己的项目需求我来想想!

  6. node和gulp版本的坑

    现在node版本最新的稳定版在14+ 然后我在接手项目的时候使用gulp打包,怎么也打包不了,这个问题纠结了挺久,然后百度了下,发现版本的问题 node 12+ 以上的版本不兼容 gulp 3的版本 ...

  7. Hbase过滤器Filter的使用心得(爬坑经验)

    Hbase 的过滤器是个好东西.. 给这种非关系型数据库本来不能复杂查询的情况得到了很好的扩展..提供了很多的帮助.. 但是Filter的种类何其之多..让人眼花缭乱.. 譬如..分页类型的PageF ...

  8. node.js:怎样同时执行多条SQLs,且只有一个回调

    本文主要介绍开源node.js库mysql-queries,其可以同时执行多条SQLs,且只有一个回调.同时抛砖引玉,与大家交流node.js开发经验. node.js很大的特点就是事件驱动.非阻塞和 ...

  9. Node.js 101(2): Promise and async

    --原文地址:http://blog.chrisyip.im/nodejs-101-package-promise-and-async 先回想一下 Sagase 的项目结构: lib/ cli.js ...

随机推荐

  1. Docker学习笔记之使用 Docker Compose 管理容器

    0x00 概述 通过之前的介绍,我们已经基本掌握了构建.运行容器的方法,但这还远远不够,由于 Docker 采用轻量级容器的设计,每个容器一般只运行一个软件,而目前绝大多数应用系统都绝不是一个软件所能 ...

  2. A-作业01

    #1 简单作业 1. 系统的日志文件/var/log/secure /var/log/messages /var/log/cron会自动的进行轮询,系统是通过什么实现的? 2. 写出下面特殊符号在定时 ...

  3. python之内置函数与匿名函数

    一内置函数 # print(abs(-1)) # print(all([1,2,'a',None])) # print(all([])) #bool值为假的情况:None,空,0,False # # ...

  4. Codeforces Round #425 (Div. 2) Problem A Sasha and Sticks (Codeforces 832A)

    It's one more school day now. Sasha doesn't like classes and is always bored at them. So, each day h ...

  5. Java中单例设计模式,饿汉式和懒汉式

    Java中单例模式是一种常见的设计模式,单例模式的写法有好几种,这里主要介绍三种:懒汉式单例.饿汉式单例.登记式单例. 单例模式有以下特点: 1.单例类只能有一个实例. 2.单例类必须自己创建自己的唯 ...

  6. ECharts公共组件:title详解、 tooltip详解、toolbox详解、legend详解、dataZoom详解、visualMap全解

    1. Title mytextStyle={ color:"#333",                           //文字颜色 fontStyle:"norm ...

  7. 解决跨域(CORS)问题

    为什么会有跨域问题 是因为浏览器的同源策略是对ajax请求进行阻拦了,但是不是所有的请求都给做跨域,像是一般的href属性,a标签什么的都不拦截 解决跨域问题的两种方式 JSONP   推荐参考 CO ...

  8. C Primer Plus 创建友好的输入界面 笔记

    看代码 char inputFunCode; while(inputFunCode = getchar()){ '){ printf("you choose string conn\n&qu ...

  9. extjs的使用笔记

    2006年jack slocum斯洛克姆 基于yui写的扩展前端框架(就是由一些前端可视化组件如表单,树, 表格,等组成的frameset或者叫做 ui engine),叫yui-ext, 后来成熟后 ...

  10. Windows操作系统下安装Ubuntu虚拟机

    认识VMware虚拟机 VMware(虚拟机)是指通过软件模拟的具有完整硬件系统功能的.运行在一个完全隔离环境中的完整计算机系统,它能在Windows系统上虚拟出多个计算机,每个虚拟计算机可以独立运行 ...