写点什么

和 Node.js 配置地狱说拜拜!Deno 零配置解决方案

作者 |Andy Jiang

  • 2023-09-19
    北京
  • 本文字数:2711 字

    阅读完需:约 9 分钟

和Node.js配置地狱说拜拜!Deno 零配置解决方案

在使用 Node.js 进行构建时,配置问题常常会影响开发人员的工作效率。好在有了 Deno,它的零配置、含“电池”设计让恼人麻烦就此讲拜拜。

 

在我们启动各种类型的 Node repo 时,root 目录很快就会被配置文件塞满。例如,在最新版本的 Next.js 中,我们就有 next.config.js、eslintrc.json、tsconfig.json 和 package.json。而在样式那边,还有 postcss.config.js 和 tailwind.config.js。

 

需要中间件不?加上 middleware.ts。错误监控不能少吧?那就再上 sentry.server.config.js、sentry.client.config.js 和 entry.edge.config.js。也别忘了我们的 env 文件、Git 文件和 Docker 文件……

 

于是还没等我们缓过神来,repo 可能就已经变成了这个样子:

 


所有软件都需要配置。毕竟我们终归要用某种方法来设置自己正在使用的项目、工具、插件和软件。但是,真有必要用 30 个文件来运行单一项目吗?我们怎么就掉进了这么恶心的配置泥潭?

 

或者说,有没有办法能摆脱困境?

 

配置,但要用上智能默认项


软件领域没有“银弹”——一切用户的需求都会略有不同。配置能让用户更灵活地根据实际用例,从软件当中汲取最大价值。

 

但“想用软件?先搞配置”确实是种非常糟糕的用户体验。

 

咱们以向现有 Next.js 项目中添加 TypeScript 为例,看看整个流程要怎么推进。首先,我们需要安装 TypeScript 和类型:

 

npm install --save-dev typescript @types/react @types/node
复制代码

 

之后需要创建自己的 tsconfig.json:

 

touch tsconfig.json
复制代码

 

接下来,如果大家刚刚开始使用 TypeScript、搞不清自己需要什么配置,那肯定要祭起开发者都知道的“秘密武器”——从 Stack Overflow 上扒一套配置:

 

{  "compilerOptions": {    "target": "es5",    "lib": ["dom", "dom.iterable", "esnext"],    "allowJs": true,    "skipLibCheck": true,    "esModuleInterop": true,    "allowSyntheticDefaultImports": true,    "strict": true,    "forceConsistentCasingInFileNames": true,    "module": "esnext",    "moduleResolution": "node",    "resolveJsonModule": true,    "isolatedModules": true,    "noEmit": true  },  "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx"],  "exclude": ["node_modules"]}
复制代码

 

不想手动往项目里添加 TypeScript 支持?可以试试 Deno,它原生支持 TypeScript。

而这,还仅仅是添加了个 TypeScript。

 

高效软件可以通过更智能的默认项来预测用户想要达成的效果。这些“预设选项”能为大多数用户提供经过优化的体验,而且无需手动配置。所以说,先给套能用的配置模板,等确有必要时再要求用户调整才是王道。

 

其实直接把软件配置页面甩到用户脸上,绝对不利于品牌的声誉、更有损客户信任。设想一下,如果我们第一次使用 Gmail,看到的是这样一幅图景:



那鬼才想用你谷歌呢,还不如继续留在 Hotmail 这边。

 

所以,智能默认项先行,有必要的时候再做配置调整。

 

这些配置文件到底是干啥的?


咱们再回到之前的列表,这些文件都在那设置啥呢?

 

  • Ignore 文件 (dockerignore, eslintignore, gitignore, prettierignore, styleignore): 它们的作用就是从操作中排除某些文件和目录。它们有助于保持环境清洁、让执行流程更高效。

  • 运行命令文件 (eslintrc.json, lintstagedrc.json, nvmrc, nycrc, stylelintrc.json, prettierrc.json, swcrc): 运行命令(rc)配置文件负责指定某些命令在运行时的设置或参数,例如 eslint、lint-staged 等。

  • 包文件 (package.json, yarn.lock): 这些文件提供的是关于自动化依赖项和脚本的重要信息,从而对项目环境进行统一管理。

  • Next.js 文件 (middleware.ts, next-env.d.ts, Next.config.js, tsconfig.json): 这些文件管理 Next.js 应用程序的设置和配置。

  • Docker (Dockerfile, Dockerfile.deploy, docker-compose.yml): 这些文件管理应用程序在容器内的自动部署和扩展配置。

  • 其他(editorconfig, happo.js, babel.config.js, playwright.config.ts, sentry.client.config.js, sentry.server.config.js, sentry.properties, ): 这些配置文件负责自定义并管理开发环境中的各方面设置,包括第三方工具和库。

 

Next.js. Docker. Sentry. Happo. ESLint. npm. Yarn. Playwright. Babel. VSCode. SWC. Stylelint. Prettier. NVM. NYC. lint-staged. Git.

 

这些工具并不深奥,属于是将 Next.js 应用程序部署到生产环境所需要的常规集合。但问题是,真需要 30 个文件那么多吗?

JavaScript 生态系统(一般来说)并不强制要求


虽然如今 Node.js 主要用于构建网站和 Web 应用,但它最初的设计目标其实没那么强烈的倾向性,更多是用事件驱动架构来启用异步 I/O。但随着 Node 的流行,JavaScript 突然就占领了高地:跟浏览器/DOM、文件系统和 Unix 交互,构建系统、捆绑、转译,等等。

 

JavaScript 的广泛实用性,在 npm 注册表中超过 200 万个模块上得到了深切体现。为了发挥作用,JavaScript 模块必须能够支持越来越多的框架、元框架、构建工具等,以便在任何情况下都能针对各种工作流程顺利接入不同项目。最直接的方法当然就是用更广泛的配置文件来保持模块的泛用能力,所以一大堆配置文件体现的其实是 JavaScript 需要跟多种框架、工具和技术栈配合使用的客观复杂性。

 

随着越来越多的工具被添加到 Node.js 项目当中,配置文件不仅变得愈发繁琐,还会降低开发人员的工作效率。

化繁为简


软件是达成目标的手段,真正高效的软件绝不会“恶心”用户,而是帮助他们快速完成任务。

 

Node.js 最初的构建目标是作为异步 I/O、由事件驱动的 JavaScript 运行时,当时的缔造者并没预料到它会对 Web 开发的日后变革发挥关键作用(目前,每三个新网页或 Web 应用中,就有一个用到 Node)。但是,当开发人员使用 Node 构建新产品时,往往需要花费大量时间来整合自己需要的技术栈和工作流程——比如设置 TypeScript、设置自己熟悉的测试框架和构建流程等。


那有没有一种办法,能让我们的 Web 构建成果立即投入生产?

 

这就是 Deno 项目的意义所在。它是一种具有零配置加智能默认项的 Web 原生运行时,您可以在开发新项目时即刻享受到它带来的效率提升。它具备原生 TypeScript 支持能力,因此无需额外花时间做设置。Deno 还附带一套强大的工具链,提供内置的格式化、linting 质量检查、测试等功能,全部开箱即用。最后,Deno 还使用与 Web 兼容的 API,所以如果大家已经在构建 Web 应用,那上手 Deno 应该不会有任何难度。

 

编程的意义就在于此:管理复杂性、化繁为简。所以,让我们携手 Deno,告别恼人的配置步骤。

 

原文链接:

https://deno.com/blog/node-config-hell

相关阅读:


Node.js 未来发展趋势

Node 之父着急宣布:Deno 将迎来重大变革,更好地兼容

Node 版本控制

Node.js 20 正式发布

2023-09-19 12:587277

评论

发布
暂无评论
发现更多内容

EndNote 21 for Mac(文献管理软件) v21.0.1激活版

mac

苹果mac Windows软件 EndNoter 参考文献管理软件

Zebec Protocol ,不止于 Web3 世界的 “Paypal”

大瞿科技

三言两语说透webpack对vue的编译

互联网工科生

源码 Vue webpack

并发中atomic BUG分享

FunTester

Zebec Protocol ,不止于 Web3 世界的 “Paypal”

威廉META

JMeter源码解析之结果收集器

优测云服务平台

Jmeter 性能测试 压力测试 #性能测试

中小企业都用哪些工具进行项目管理?

易成管理学

项目管理 PingCode 项目管理软件

企业选择大文件传输软件的真正原因

镭速

大文件传输软件

HTML5 Canvas 和 SVG哪个简单好用

2D3D前端可视化开发

html5 SVG 数据可视化 canvas 前端设计

不容错过的MSBuild技巧,必备用法详解和实践指南

这我可不懂

自动化构建工具 MSBuild Visual Studio

使用appuploader工具流程(Windows版本)

适合自己企业的erp系统怎么选?这8条关键因素缺一不可!

优秀

ERP系统

TextBrewer:融合并改进了NLP和CV中的多种知识蒸馏技术、提供便捷快速的知识蒸馏框架、提升模型的推理速度,减少内存占用

汀丶人工智能

人工智能 自然语言处理 知识蒸馏

梳理日常开发涉及的负载均衡

WizInfo

负载均衡 网关

大文件传输软件| 生命科学中的关键因素

镭速

大文件传输快速

AREX 如何支持 Dubbo 自定义私有协议的录制回放

AREX 中文社区

dubbo 自动化测试 流量回放 流量录制

斩获可信云最佳实践,天翼云存储资源盘活系统助力“一云多芯”!

天翼云开发者社区

云计算 存储

AI融入管理软件,是否会是下一个“ERP时代”的前奏?

B Impact

让三驾马车奔腾:华为如何推动空间智能化发展?

脑极体

全屋智能

10. 数据类型 - 元组详解

茶桁

Python 数据类型 tuple

Zebec Protocol ,不止于 Web3 世界的 “Paypal”

股市老人

用低代码开发平台构建高效敏捷工作流

力软低代码开发平台

Windows上值得推荐的6款冷门软件

这我可不懂

工具 windows 高效率

Llama2 评测大公开!知识库场景下能否赶超 ChatGPT?

Zilliz

Zilliz Towhee ChatGPT llama llama2

吴声年度演讲,关于Notion 的“模版”和 CLG |highlight

B Impact

NFTScan | 07.31~08.06 NFT 市场热点汇总

NFT Research

NFT\

拨开迷雾:利用全链路消息跟踪揭示系统奥秘

鲸品堂

数据库 分布式 全链路 企业号 8 月 PK 榜

使用 RKE 方式搭建 K8s 集群并部署 NebulaGraph

NebulaGraph

k8s

erp系统都有哪几家,如何选择适合自己企业的erp系统?

优秀

ERP系统

k8s安装prometheus

tiandizhiguai

k8s Promethues

和Node.js配置地狱说拜拜!Deno 零配置解决方案_框架_InfoQ精选文章