我与Node.js的一年半

1,182 阅读5分钟

从2016年在yelp hackathon里第一次接触node.js以及其相关的stack(MEAN),我就被深深吸引了。当初的印象是,这开发web app好快啊,一分钟配置端口,搭好服务器,跑起来hello world node.js。我的第一个nodejs app是聊天室+地图,用到socket.io,这也刷新了我的三观,同时也让我对async印象深刻。

我的第一个node项目:talkover.party
我的第一个node项目:talkover.party

后来又参加了shop.com的hackathon,不用说,就用nodejs。这次啊,造了个轮子,不都说造轮子比较高大上么。给shop.com原有的api做了个nodejs版本的。这次照着node-yelp的葫芦,画了个自己瓢,还接触到了Promise。不光是造轮子,还得测试啊,所以又接触了assert。虽然没太多人用,不过也是挺有成就感,毕竟为community做了贡献。

过了几个月快毕业了,这一次是给XXX安全公司做项目(在试用python stack失败后,我强烈建议转到node stack),是给一个mobile app做server。因为项目特定的需求,除了接触到node中restful api的设计与实现,还搞了不少安全相关的东西。毕竟是毕业项目,而且是真的会有XXX公司的人用,再加上上一次node项目屎一样文件结构的经验,这次我做了些研究,关于文件结构,ngnix的配置还有一些best practice。这次项目的印象是,这开发web app好方便啊,一分钟(一般要试用几个类似的package,看看哪个比较适合)在npm找到你想用的package,安装读文档,然后就用!

就是方便,就是快,要啥有啥
就是方便,就是快,要啥有啥

自此我从没读过任何nodejs书籍,全靠online tutorial,documents以及照葫芦画瓢做东西(stackoverflow就用不用说了)。东西还是照样做,感觉读个啥书。

读个啥书?!
读个啥书?!

毕业了找到工作之后,又想开始浪(用闲置时间做项目)。毫无疑问的选择了node,不考虑应用场景, 就是单纯的为了通过做东西学更多nodejs的东西。这次主要做了爬虫,接触到了cheerio,request以及另外刷新三观的auth0。这东西好啊,妈妈再也不用担心登陆注册、用户管理了。由于这段时间做了和找工作相关的项目,然后发现glassdoor只有一个package,为了蹭热点,我也搞了一个,就是要比那一个好!然后还做了一个获取公司h1b信息的package,方便我再项目里调用。

这期间搞到了《深入浅出nodejs》还有《nodejs高级编程》,准备开始读,大概翻了翻,觉得这我都『差不多』知道啊,于是就拖拖拉拉大概看了看。

假装在读
假装在读

浪了没几个星期,去了tufts的一个hackathon,这次更是收获满满,因为是24小时hackathon,之后还要presentation,所以为了加快开发速度,把更多时间放到真正功能的开发上。我发现了另一个神器,hackathon-starter。在这个样板的帮助下,完成了hackathon,但他的作用不止于此。我发现他的文件结构可以和我之前搜到的best practice结合,这样我就有了一套自己顺手的文件结构,感觉棒棒的。之后的项目就可以轻轻松松开始。除了hackathon-starter,还结识了『加油女孩』微光基金项目的成员。他们到hackathon里面去找中国人,然后看有没有兴趣帮他们开发。我心想,反正也没事儿,而且这是个公益活动(头一次觉得自己写的代码这么有社会意义),最主要我还是可以用nodejs,就这样决定了。之后的四五个月时间(主要是头两个月集中开发,后面属于针对某些需求的改动再做的一些边边角角的开发),就基本下班回家搞这个。这一次项目更大了(前所未有的大),从设计到实现,从客户端到管理员端,从model分析设计到怎么保证数据的安全,从项目开发到不同环境(dev, qa, production)的部署。印象比较深的几个package是helmet,lusca(安全相关),i18n(国际化),async(收获最大的一个,功能复杂之后,callback一层套一层,真的是callhack hell了),在一个就是发现handlebar这个前端引擎既有的功能很少,于是接触了怎么自定义一些操作,让引擎更加强大,服务器放方面接触了forever和pm2,感觉pm2相对好一点,之后还要部署https,搞了成千上万次,后来在certbot的帮助下完成了(后来想起来貌似cloudflare可以帮助自动变成https)。

忙完这个公益项目之后,就现在了,虽然还是在做东西,还是用nodejs。有一个想法越来越频繁的出现在我脑海里,对于nodejs我到底是在学什么,是学习具体的package怎么用吗?!都说看源码,理解怎么工作的,这个真的有用吗?是在什么方面有用呢?

带着这些疑问,我决定认认真真的看一下课程,读一下书,从原理读起。之前我的学习方法是learning by doing,现在开始从原理学起。也用亲身经历来验证下(极端的)实践派学习方法以及(符合学习方法的)理论派学习方法,到底会给我带来什么不同的收获!(接下来会持续更新...)

上面提到的package/repo/project:

  1. socket.io: socket.io/
  2. node-yelp: github.com/olalonde/no…
  3. node-shop.com: www.npmjs.com/package/nod…
  4. cheerio: www.npmjs.com/package/che…
  5. hackathon-starter: github.com/sahat/hacka…
  6. auth0: auth0.com/
  7. node-glassdoor: www.npmjs.com/package/nod…
  8. node-h1bvisa: www.npmjs.com/package/nod…
  9. lusca: www.npmjs.com/package/lus…
  10. helmet: www.npmjs.com/package/hel…
  11. async: www.npmjs.com/package/asy…
  12. pm2: www.npmjs.com/package/pm2
  13. forever: www.npmjs.com/package/for…
  14. i18n: www.npmjs.com/package/i18…
  15. certbot: certbot.eff.org/
  16. assert: www.npmjs.com/package/ass…