视野修炼-技术周刊第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。

⭐️强力推荐关注

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

相关推荐
祈祷苍天赐我java之术7 分钟前
Vue 整体框架全面解析
前端·javascript·vue.js
洛小豆1 小时前
Git 打标签完全指南:从本地创建到远端推送
前端·git·github
王道长服务器 | 亚马逊云1 小时前
一个迁移案例:从传统 IDC 到 AWS 的真实对比
java·spring boot·git·云计算·github·dubbo·aws
世间小小鱼1 小时前
【爬坑指南】亚马逊文件中心 AWS S3 预签名URL 前端直传
前端·云计算·aws
华仔啊1 小时前
前端登录token到底应该存在哪?LocalStorage、SessionStorage还是Cookie?一篇说透!
前端·javascript
BeefyBytes1 小时前
动态组件库建设
前端
懒大王95271 小时前
uni-app + Vue3 + EZUIKit.js 播放视频流
开发语言·javascript·uni-app
懒大王95272 小时前
uni-app + Vue3 开发展示 echarts 图表
前端·uni-app·echarts
yinuo2 小时前
Uni-App跨端实战:微信小程序WebView与H5通信全流程解析(01)
前端
xkroy2 小时前
ajax
前端·javascript·ajax