视野修炼-技术周刊第115期 | 现代的 Nodejs 能力

欢迎来到第 115 期的【视野修炼 - 技术周刊】,下面是本期的精选内容简介

🔥强烈推荐

  1. 一些现代的 Nodejs 能力

🔧开源工具&技术资讯

  1. MarkItDown
  2. ReactAI

🤖AI工具&资讯

  1. 背景移除
  2. 智能图片描述生成器生成器

下面开始今年最后一期内容的介绍,预计阅读时间 5 分钟。

🔥强烈推荐

1. 一些现代的 Nodejs 能力

  1. 单测相关
js 复制代码
import assert from 'node:assert'
import fs from 'node:fs/promises'
import { mock, test } from 'node:test'
import { add } from '../src/math.js'

test('should add two numbers', () => {
  const result = add(1, 2)
  assert.strictEqual(result, 3)

  // mock 返回结果
  const mockImplementation = async (path) => {
    return 'PORT=3000\n'
  }
  const mockedReadFile = mock.method(fs, 'readFile', mockImplementation)
})
  1. watch 文件变动自动重新运行
sh 复制代码
node --watch app.js

node --watch 'lib/**/*.js' app.js
  1. Corepack 管理包管理器的工具
json 复制代码
{
  "packageManager": "yarn@2.4.1"
}
sh 复制代码
corepack enable
  1. env 文件读取
sh 复制代码
# 单个文件
node --env-file=./.env index.js

# 多个文件
node --env-file=./.env.default --env-file=./.env.development index.js
  1. esm 下提供__dirname 和 __filename

在这之前 ESM 里获取方式如下

js 复制代码
import url from 'url'
import path from 'path'

const dirname = path.dirname(url.fileURLToPath(import.meta.url))

现在可以直接使用

js 复制代码
const { dirname: __dirname, filename: __filename } = import.meta
  1. 定时器 Promise

在这之前,你会这样实现一个 sleep

js 复制代码
function sleep(ms) {
  return new Promise(resolve => setTimeout(resolve, ms))
}

现在你可以直接使用

js 复制代码
import { setTimeout } from 'timers/promises'

function sleep(ms) {
  return setTimeout(ms)
}
sleep(1000).then(() => {
  console.log('1s passed')
})

🔧开源工具&技术资讯

2. MarkItDown

将各种格式的文件转换为 Markdown 格式的在线工具,支持 Word、PDF、HTML、图片等格式。

还支持直接指定网页链接。

你可能会好奇图片怎么转 Markdown?验证了一下是转换成一段文本描述图片内容。

3. ReactAI

开源免费AI React组件构建器。

编写提示词,只需几秒钟即可创建功能完整的React组件!

浅尝了一下,效果没有 Bolt

🤖AI工具&资讯

4. 背景移除

还有另一样功能的 remove.bgremovebg.one

5. 智能图片描述生成器生成器

生成的文本可用于 img alt 属性填充,进而优化网站的 SEO。

⭐️强力推荐关注

周刊部分内容来源如下渠道,推荐大家关注。

相关推荐
kyriewen9 小时前
别再 console.log 了:5 个 Chrome DevTools 调试技巧,用过就回不去了
前端·javascript·面试
IT_陈寒11 小时前
Python搞不定字符串编码?这破玩意坑我两小时!
前端·人工智能·后端
To_OC11 小时前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
DigitalOcean12 小时前
Laravel 开发者已在 DigitalOcean 上开通超过 10 万台服务器
前端·laravel
星始流年13 小时前
从 Tool 到 Skill——基于 LangChain 的服务端Skill实现
前端·langchain·agent
李惟13 小时前
开源本地通信库,纯客户端 RPC,像聊天一样通信
前端
YAwu1113 小时前
深入解析 React 炫彩鼠标跟随标题组件:从坐标定位到动画性能
前端·react.js
GuWenyue13 小时前
排序效率低?5分钟吃透快速排序,性能飙升至O(nlogn)
前端·javascript·面试
OpenTiny社区13 小时前
🎨 看完 GenUI SDK 源码我悟了!
前端·vue.js·github
叁两13 小时前
前端转型AI Agent该如何学习?(前置篇)
前端·人工智能·node.js