2019年10月

  1. It is rendered once on the server - it is the root of your app
  2. App's getInitialProps is called before anything else - even before getInitialProps in _document.js
  3. It is created and mounted ONLY ONCE on the client - when the page first loads. Thereafter, on page navigation, App.getInitialProps is called before each page, and then its render function is called, to render the incoming page.

- 阅读剩余部分 -

我不是个人开发者,最多算半个,毕竟有一份正式的工作,这个应该是 side project。最近在做一个 blog,实现 Headerless CMS + React 这个概念。

这不是我第一个 side project,但却是我坚持最久,并且实现最完整的一个,而且确实克服了很多困难。

主要原因是用了一个 Github 的 feature:Project,其实就是简版的 Jira。

我每次想到什么好的点子,要修复的 bug,或者想要实现的 feture,都记录下来。然后一个个解决,当把已经解决的问题挪到“Closed”栏的时候,还是很有成就感的。

而且每个问题,有优先级,排个先后顺序。

这样真正可以把项目一点一滴向前推进。

- 阅读剩余部分 -

看新闻,有一个小公司叫做Zingle,可以给公司发短信,比如定酒店、叫客房服务,甚至买咖啡,最近被收购了,4200万美元现金。

挺好玩的,但说明什么,这个idea其实就是多渠道客户服务对接系统,比如你有个twitter账户,有人在twitter上at你们公司,对吧, 订酒店,买咖啡等等。我自己给取了一个英文名称,Multi-Channel Customer Engaging System,也不知道对不对。

那么,既然短信可以,能不能email呢?facebook呢?公司的博客系统呢?Whatsapp ? Facebook Messager? Instagram ? 等等,你们公司在一切社交网络上的账户,能不能用来为客户提供服务呢?

这注定是个脏活累活,但这显然是有钱途的活。

新闻如下:

- 阅读剩余部分 -

最近沉迷 SSR,因为考虑到了一些需求:

  • SEO
  • Social sharing

当然了,谷歌牛逼,都能直接解析 SPA 了,但问题我主要还是一个用户体验上:用户点击一个 url,SPA 就 404 了,但一个体验很好的网站,显然希望是能够加载出来的。下面是Vuejs的SSR网站对SEO问题的解释:

Better SEO, as the search engine crawlers will directly see the fully rendered page.

Note that as of now, Google and Bing can index synchronous JavaScript applications just fine. Synchronous being the key word there. If your app starts with a loading spinner, then fetches content via Ajax, the crawler will not wait for you to finish. This means if you have content fetched asynchronously on pages where SEO is important, SSR might be necessary.

所以就开始了迁移,从 React SPA 迁移到 nextjs。

nextjs 很多大坑,比如说:

  • getInitialProps 只能在pages这个目录下用
    • _app.js 里不建议用 getInitialProps
  • 关于 router:
    • Link 其实是客户端 routing,
    • router ( useRouter 和 withRouter )的话, push就是服务端 routing,
    • router 不能像 react-router 那样带state (我看某个 issue 这么些的,想和各位确认一下)
  • PM2 部署
    • 还是需要用express做一个中间层
    • 也有用koa2做中间层的,但我没再折腾了
    • 如果不用,直接pm2 start next start也行,但我还是希望用到ecosystem.config.js这个文件写配置
  • Webpack配置的坑:
  • next.config.jsde 问题
    • 首先是不要用.env,而要用这个配置文件里的env
  • 一些迷
    • 反正就是总会出现一些迷一样的 error,反正还有点搞不清