2020 年 Node.js 开发者调查报告

简介: 本次调查由阿里巴巴、腾讯等公司领衔,调查时间从 2020 年 2 月至 4 月,以中文进行。截止至 4 月 10 日共有 1113 名受访者参加调研。本报告将从 Nodejs 开发者人群、应用场景、开发场景等多个维度分析当下 Nodejs 开发生态的现状。

作者:冰森

image.png

导读:本次调查由阿里巴巴、腾讯等公司领衔,调查时间从 2020 年 2 月至 4 月,以中文进行。截止至 4 月 10 日共有 1113 名受访者参加调研。本报告将从 Nodejs 开发者人群、应用场景、开发场景等多个维度分析当下 Nodejs 开发生态的现状。

更好的阅读体验:更高清的数据图表和交互体验可以点击阅读原文跳转至相关 GitHub 页面查看。

受访者

人物来源

本次调查问卷中,填写问卷的 Node.js 开发者主要年龄分布如下:

image.png

他们的主要分布情况为:

image.png

其中以城市角度看,人数分布主要是:

image.png

职业简历

  • 典型的受访者来自两种公司,分别是百人左右的小型公司,以及 5k 人以上的大公司。
  • 他们通常是 7 人左右的团队内的前端或者全栈工程师。

image.png

工作内容

应用场景

  • Node.js 的典型应用场景是网站开发。
  • 大公司内会有更多的人使用 Node.js 进行工具 & 自动化开发。
  • 中小公司会更乐意在移动应用中尝试 Node.js。
  • 不少人 (35.01%) 学习 Node.js 是出于业余爱好,在小公司更加明显。

image.png

开发场景

  • 整体而言有 87.50% 使用 Node.js 开发服务端 API,有 51.19% 的人开发 CLI & 工具。
  • 随着使用年限增加将 Node.js 作为服务端 API 的比率略有下降 (5%) 而 BFF 的使用场景略有上涨 (4%)。
  • 越年轻的使用者越愿意在 SSR 场景中使用 Node.js。

image.png

多语言

  • 与 Node.js 开发最契合的是前端开发语言(JavaScript/HTML/CSS)。
  • 除了前端,整体上与 Node.js 最常见并存的语言分别是 Java(25.27%)、Python(22.24%) 和 Go(17.73%)。

image.png

开发流程

代码转译

  • 随着 Node.js 使用年限增加,不转译的比率大幅下降 (45% 到 25%)。
  • TypeScript 是最常用的转译语言。

image.png

代码检查

  • 整体上有 90% 的 Node.js 开发者使用过 ESLint。
  • 随着团队规模的增大 TSLint 的使用存在微小的增幅。

image.png

配置方式

  • 文件配置是最流行的配置方式。
  • 虽然配置中心使用概率不高,不过公司规模越大则配置中心的使用概率越高。

image.png

编辑器

  • VS Code 一骑绝尘,是 Node.js 开发者最喜爱开发工具

image.png

进程管理

  • 公司越大使用 Docker 的比例越高。
  • 中型公司使用 PM2 的比例更高。

image.png

操作系统

image.png

技术栈

一个典型的 Node.js Web 应用:

  • 使用 Express/Koa 框架
  • 使用 Mysql/MongoDB + Redis 数据
  • 同时配置了 Nginx 作为反向代理

Web 框架

  • 虽然感受上 Koa.js 的教程更多,但是实际上 Express.js 依旧是最常见的框架。
  • 除了 Koa/Express 之外较流行的 Web 框架分别有 Egg.js (38%)、Nest.js (15%)、Next.js (7%) 和 Midway.js (6%)。

image.png

数据库

在 2020 年,如果要学三个数据库,那么请学习 MySQL (79%)、MongoDB (60%) 和 Redis (49%)。

image.png

反向代理

  • Noder 们对于反向代理的概念是约等于 Nginx 的。
  • 使用反向代理的基本都会使用 Nginx。
  • 越大的公司越倾向于使用反向代理。

image.png

RPC

  • HTTP 是最常见的 RPC 方式,此外使用最多的是消息队列。
  • 中型公司使用消息队列的比率最高。
  • 大公司使用自研 RPC 协议的比率最高。

image.png

消息队列

  • 常用的消息队列(多选) 仅 18% 的同学填写消息队列(问卷星渠道不包括)

image.png

开发生态

Node 版本

  • 在 2020 年,开发者们普遍使用 12.x 或更高版本 13.x。
  • 除了 NPM, 最流行的管理工具主要是 yarn 以及 cnpm。
  • 仅有不到 6% 的开发者在使用非 LTS 版本的 Node.js。

image.png

依赖管理

  • NPM 影响力巨大,仅有不到 6% 的同学可以摆脱 NPM 只使用其他的依赖管理工具。
  • 除了 NPM, 最流行的管理工具主要是 yarn 以及 cnpm。
  • 随着开发经验的增加,开发者会更多的试图寻找 NPM 以外的依赖管理工具。

image.png

NPM 镜像

  • 使用镜像加速的同学超过 57%,但是这对 NPM 的下载速度并没有起到决定性的影响。
  • 通过比例分析可以发现,除了镜像加速,下载速度越快的同学中公司部署私有 NPM 镜像的比例越高。

image.png

学习提升

学习途径

  • 老司机更多的从开源代码 (Github & NPM) 来学习 Node.js。
  • 新同学相比之下会更多的通过学习视频以及博客 & 期刊等渠道学习。

image.png

使用困惑

  • Node 开发者使用困惑的前三分别是性能优化 (58%)、内存泄漏 (42.4%) 以及 Debug (24.89%)。
  • 新人更容易面临的困惑前三分别是 异步编程、事件驱动以及 Debug。
  • 随着开发经验的增加,内存泄漏的比例也逐步上升。

image.png

资源需求

  • 文档是大家最期待的资源。
  • 新同学对视频教程和免费在线课程的呼声最高。
  • 随着开发经验的增加,开发更加关注文档、大会活动以及线下沙龙。

image.png

未来关键字

  • Serverless 和多线程是 2020 年的 Noder 们最关注的新关键字。
  • 从业经验越高则越关注 WebAssembly (WASI) 和 N-API。
  • 越年轻的同学越关注 Deno。

image.png

生态期望

  • Node.js 开发者中呼声最高的需求是更好的性能以及开发效率。
  • 此外不满 1 年的开发者更关心学习成本,年限越长越关心维护成本。

image.png

最后

同样的数据在不同的人眼里可以衍生出不同的看法,本报告内的解读仅供参考。同时欢迎社区同学对本报告进行解读和分析。

如果发现有疏漏或者有你自己的想法/吐槽都可以在 GitHub 上提 issue 反馈。

原文链接


image.png
关注「Alibaba F2E」
把握阿里巴巴前端新动向

相关文章
|
6月前
|
JSON JavaScript 前端开发
掌握 JavaScript:从初学者到高级开发者的完整指南之JavaScript对象(二)
掌握 JavaScript:从初学者到高级开发者的完整指南之JavaScript对象(二)
|
3月前
|
运维 JavaScript Serverless
Serverless革命:一键上云,Egg.js开发者的超级加速器!
【8月更文挑战第8天】本教程介绍如何结合Egg.js与Serverless技术简化Web应用部署。首先确保已安装Node.js及npm,并使用`egg-init`脚手架创建新应用。接着添加`egg-serverless`插件支持Serverless部署,编写基本的应用代码及路由规则。通过配置`fc.yml`文件集成阿里云Function Compute作为Serverless平台,并借助`@alicloud/fun`工具完成部署。最后,通过部署生成的URL验证应用是否成功上线。采用Serverless架构,开发者可以专注于业务逻辑,大幅提高部署效率和资源利用。
56 5
|
3月前
|
JavaScript 前端开发 测试技术
Vue.js开发者必看!Vue Test Utils携手端到端测试,打造无懈可击的应用体验,引领前端测试新风尚!
【8月更文挑战第30天】随着Vue.js的普及,构建可靠的Vue应用至关重要。测试不仅能确保应用质量,还能提升开发效率。Vue Test Utils作为官方测试库,方便进行单元测试,而结合端到端(E2E)测试,则能构建全面的测试体系,保障应用稳定性。本文将带你深入了解如何使用Vue Test Utils进行单元测试,通过具体示例展示如何测试组件行为;并通过Cypress进行E2E测试,确保整个应用流程的正确性。无论是单元测试还是E2E测试,都能显著提高Vue应用的质量,让你更加自信地交付高质量的应用。
66 0
|
3月前
|
JavaScript 开发者 UED
Vue.js组件库大对决:Element UI与Vuetify,开发者的罗密欧与朱丽叶!
【8月更文挑战第30天】Element UI和Vuetify是Vue.js开发中的热门组件库,前者简洁高效,后者遵循Material Design,国际化程度高。两者均提供丰富的组件支持,但Vuetify组件更多样,设计更灵活;Element UI在性能和中文支持上更优。文档方面,Element UI更直观易懂,而Vuetify配置灵活但学习成本稍高。选择时需综合考虑项目需求、团队背景及设计风格,以达到最佳开发效果。
172 0
|
5月前
|
JavaScript 前端开发 编译器
探讨TypeScript如何帮助JavaScript开发者避免这些常见错误,从而提高代码质量和开发效率
【6月更文挑战第13天】TypeScript,JavaScript的超集,通过添加静态类型检查和面向对象特性,帮助开发者避免常见错误,提升代码质量和开发效率。它能检测类型错误,防止运行时类型转变引发的问题;使用可选链和空值合并避免引用错误;通过枚举减少逻辑错误中的魔法数字;接口和泛型等特性提高代码可维护性。学习TypeScript对提升JavaScript开发质量有显著效果。
60 4
|
5月前
|
JavaScript Java 测试技术
基于ssm+vue.js+uniapp小程序的网上系统调查附带文章和源代码设计说明文档ppt
基于ssm+vue.js+uniapp小程序的网上系统调查附带文章和源代码设计说明文档ppt
21 0
|
6月前
|
JavaScript 前端开发 安全
【JavaScript与TypeScript技术专栏】TypeScript如何帮助JavaScript开发者避免常见错误
【4月更文挑战第30天】TypeScript,JavaScript的超集,通过静态类型检查和面向对象特性,帮助开发者避免类型错误、引用错误和逻辑错误,提升代码质量和可维护性。它引入类型注解、接口、可选链和空值合并,使代码更清晰、安全。对于大型项目,TypeScript的接口、类和泛型有助于代码结构化和模块化。学习TypeScript能提高JavaScript开发效率。
48 0
|
6月前
|
前端开发 JavaScript API
网页开发者必看!5种JS跳转页面技巧,提升用户交互体验
欢迎来到前端入门之旅!这个专栏是为那些对Web开发感兴趣、刚刚开始学习前端的读者们打造的。无论你是初学者还是有一些基础的开发者,我们都会在这里为你提供一个系统而又亲切的学习平台。我们以问答形式更新,为大家呈现精选的前端知识点和最佳实践。通过深入浅出的解释概念,并提供实际案例和练习,让你逐步建立起一个扎实的基础。无论是HTML、CSS、JavaScript还是最新的前端框架和工具,我们都将为你提供丰富的内容和实用技巧,帮助你更好地理解并运用前端开发中的各种技术。
|
6月前
|
前端开发 JavaScript 安全
JavaScript 中的宿主对象和原生对象:开发者必知的基础知识(下)
JavaScript 中的宿主对象和原生对象:开发者必知的基础知识(下)
JavaScript 中的宿主对象和原生对象:开发者必知的基础知识(下)
|
6月前
|
XML 存储 JavaScript
JavaScript 中的宿主对象和原生对象:开发者必知的基础知识(上)
JavaScript 中的宿主对象和原生对象:开发者必知的基础知识(上)
JavaScript 中的宿主对象和原生对象:开发者必知的基础知识(上)
下一篇
无影云桌面