Node.js实用的内置API(二)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介: 在构建 Node.js 应用程序时,了解 Node.js 开箱即用的实用程序和 API 有助于满足常见用例和开发需求。在文中《Node.js实用的内置API(一)》介绍了两个,本文继续介绍其他实用内置API。

在构建 Node.js 应用程序时,了解 Node.js 开箱即用的实用程序和 API 有助于满足常见用例和开发需求。在文中《Node.js实用的内置API(一)》介绍了两个,本文继续介绍其他实用内置API。

  • util:提供了各种有用的 JavaScript 方法,其中最有用的是 util.promisify(function),它采用错误优先的回调样式函数并返回基于 Promise 的函数。
  • URL:另一个全局对象,安全地创建、解析和修改 Web URL。它对于从 URL 中快速提取协议、端口、参数和 hash 非常有用,而无需借助正则表达式。
  • 文件系统:可以创建、读取、更新和删除文件、目录和权限。

Util

util 模块提供了各种有用的 JavaScript 方法,其中最有用的是 util.promisify(function),它采用错误优先的回调样式函数并返回基于 Promise 的函数。Util 模块还可以帮助处理常见模式,例如解码文本、类型检查和检查对象。

  • util.callbackify(function):接受一个返回承诺的函数并返回一个基于回调的函数。
  • util.isDeepStrictEqual(object1, object2):当两个对象之间存在深度相等时返回 true(所有子属性必须匹配)。
  • util.format(format, [args]):使用类似 printf-like-format 返回一个字符串
  • util.inspect(object, options):返回用于调试的对象的字符串表示形式,类似于使用 console.dir(object, { depth: null, color: true });
  • util.stripVTControlCharacters(str):从字符串中去除 ANSI 转义符
  • util.types:为常见的 JavaScript 和 Node.js 值提供类型检查,如下:
import util from "util";
util.types.isDate(new Date()); // true
util.types.isMap(new Map()); // true
util.types.isRegExp(/abc/); // true
util.types.isAsyncFunction(async () => {}); // true

URL

URL 是另一个全局对象,安全地创建、解析和修改 Web URL。它对于从 URL 中快速提取协议、端口、参数和 hash 非常有用,而无需借助正则表达式。如下:

{
    href: "https: //example.org:8000/path/?abc=123#target",
    origin: "https: //example.org:8000",
    protocol: "https:",
    username: "",
    password: "",
    host: "example.org: 8000",
    hostname: "example.org",
    port: "8000",
    pathname: "/path/",
    search: "?abc=123",
    hash: "#target",
}

可以查看和更改任何属性,如下:

const myUrl = "https://example.org:8001/path/?abc=123#target";
myURL.port = 8001;
console.log(myURL.href); // https://example.org:8001/path/?abc=123#target

然后,可以使用 URLSearchParamsAPI 修改查询字符串值,如下:

myURL.searchParams.delete("abc");
myURL.searchParams.append("xyz", 987);
console.log(myURL.search); // ?xyz=987

dns 模块提供名称解析功能,可以查找 IP 地址、名称服务器、TXT 记录和其他域信息。

文件系统 API

文件系统 APIfs 可以创建、读取、更新和删除文件、目录和权限。 Node.js 运行时的最新版本在 fs/promises 中提供了基于 Promise 的函数,这使得管理异步文件操作变得更加容易。

经常将 fspath 结合使用来解析不同操作系统上的文件名。

以下代码模块使用 stataccess 方法返回有关文件系统对象的信息:

import { constants as fsConstants } from "fs";
import { access, stat } from "fs/promises";
export async function getFileInfo(file) {
    const fileInfo = {};
    try {
        const info = await stat(file);
        fileInfo.isFile = info.isFile();
        fileInfo.isDir = info.isDirectory();
    } catch (e) {
        return { new: true };
    }
    try {
        await access(file, fsConstants.R_OK);
        fileInfo.canRead = true;
    } catch (e) {}
    try {
        await access(file, fsConstants.W_OK);
        fileInfo.canWrite = true;
    } catch (e) {}
    return fileInfo;
}

当传递一个文件名时,该函数返回一个包含该文件信息的对象,如下:

{
  isFile: true,
  isDir: false,
  canRead: true,
  canWrite: true
}

主程序 filecompress.js 脚本使用 path.resolve() 将命令行上传递的输入和输出文件名解析为绝对文件路径,然后使用 getFileInfo() 获取信息:

#!/usr/bin/env node
import path from "path";
import { readFile, writeFile } from "fs/promises";
import { getFileInfo } from "./lib/fileinfo.js";
// check files
const input = path.resolve(process.argv[2] || "");
const output = path.resolve(process.argv[3] || "");
const [inputInfo, outputInfo] = await Promise.all([
    getFileInfo(input),
    getFileInfo(output),
]);
const error = [];

该代码验证路径并在必要时以错误消息终止:

if (outputInfo.isDir && outputInfo.canWrite && inputInfo.isFile) {
    output = path.resolve(output, path.basename(input));
}
if (!inputInfo.isFile || !inputInfo.canRead)
    error.push(`cannot read input file ${input}`);
if (input === output) error.push("input and output files cannot be the same");
if (error.length) {
    console.log("Usage: ./filecompress.js [input file] [output file|dir]");
    console.error("\n  " + error.join("\n  "));
    process.exit(1);
}

使用 readFile() 将整个文件读入名为 content 的字符串:

console.log(`processing ${input}`);
let content;
try {
    content = await readFile(input, { encoding: "utf8" });
} catch (e) {
    console.log(e);
    process.exit(1);
}
const lengthOrig = content.length;
console.log(`file size  ${lengthOrig}`);

JavaScript 正则表达式然后删除注释和空格:

content = content
    .replace(/\n\s+/g, "\n") // 移除行前置空格
    .replace(/\/\/.*?\n/g, "") // 移除单行注释
    .replace(/\s+/g, " ") // 移除空格
    .replace(/\/\*.*?\*\//g, "") // 移除块注释 /* 注释 */
    .replace(/<!--.*?-->/g, "") // 移除HTML注释 <!-- 注释 -->
    .replace(/\s*([<>(){}}[\]])\s*/g, "$1") // 移除括号周围的空格
    .trim();
const lengthNew = content.length;

使用 writeFile() 将生成的字符串输出到文件中,并且状态消息会显示保存:

const lengthNew = content.length;
// write file
console.log(`outputting ${output}`);
console.log(
    `file size  ${lengthNew} - saved ${Math.round(
        ((lengthOrig - lengthNew) / lengthOrig) * 100
    )}%`
);
try {
    content = await writeFile(output, content);
} catch (e) {
    console.log(e);
    process.exit(1);
}

使用示例 HTML 文件运行项目代码:

node filecompress.js ./test/example.html ./test/output.html


相关文章
|
1月前
|
缓存 JavaScript 前端开发
深入浅出:使用Node.js构建RESTful API
【9月更文挑战第3天】在数字化浪潮中,后端开发如同搭建一座连接用户与数据的桥梁。本文将带领读者从零开始,一步步用Node.js搭建一个功能完备的RESTful API。我们将探索如何设计API的结构、处理HTTP请求以及实现数据的CRUD操作,最终通过一个简单的实例,展示如何在真实世界中应用这些知识。无论你是初学者还是有一定经验的开发者,这篇文章都会为你揭示后端开发的奥秘,让你轻松入门并掌握这一技能。
70 3
|
16天前
|
JavaScript 前端开发 API
JavaScript 验证 API
JavaScript 验证 API
18 2
|
2月前
|
JavaScript NoSQL API
深入浅出:使用Node.js构建RESTful API
【8月更文挑战第31天】本文将引导读者了解如何利用Node.js搭建一个高效、易于扩展的RESTful API。通过简单易懂的语言和逐步深入的内容组织,我们将一起探索Node.js在后端开发中的实际应用,包括环境配置、路由设计、数据处理与连接数据库等关键步骤。文章末尾,你将获得完整的项目代码示例,助你快速启动自己的API项目。
|
1月前
|
JSON JavaScript 中间件
深入浅出Node.js: 从零开始构建RESTful API
【8月更文挑战第34天】 在数字时代的浪潮中,掌握如何构建高效、可靠的后端服务是每一位开发者的必备技能。本文将通过浅显易懂的语言和实际代码示例,带领初学者走进Node.js的世界,一步步搭建起自己的RESTful API。无论你是编程新手,还是想扩展技术栈的老手,这篇文章都将是你的良师益友。让我们一起探索Node.js的魅力,开启后端开发之旅!
|
2月前
|
JSON JavaScript 中间件
深入浅出Node.js: 从零开始构建RESTful API
【8月更文挑战第31天】 在数字时代的浪潮中,掌握如何构建高效、可靠的后端服务是每一位开发者的必备技能。本文将通过浅显易懂的语言和实际代码示例,带领初学者走进Node.js的世界,一步步搭建起自己的RESTful API。无论你是编程新手,还是想扩展技术栈的老手,这篇文章都将是你的良师益友。让我们一起探索Node.js的魅力,开启后端开发之旅!
|
2月前
|
JavaScript 前端开发 API
深入浅出:使用Node.js打造简易Web API
【8月更文挑战第31天】本文旨在通过一个简单实例,引导读者快速入门Node.js并创建自己的Web API。我们将从零开始,一步步搭建起服务端应用,涉及环境搭建、基本语法、路由处理等关键知识点,最后以代码实例加深理解。无论你是前端开发者还是后端新手,这篇文章都能让你轻松上手,体验后端开发的乐趣。
|
2月前
|
机器人 API Python
智能对话机器人(通义版)会话接口API使用Quick Start
本文主要演示了如何使用python脚本快速调用智能对话机器人API接口,在参数获取的部分给出了具体的获取位置截图,这部分容易出错,第一次使用务必仔细参考接入参数获取的位置。
121 1
|
12天前
|
安全 API 开发者
Web 开发新风尚!Python RESTful API 设计与实现,让你的接口更懂开发者心!
在当前的Web开发中,Python因能构建高效简洁的RESTful API而备受青睐,大大提升了开发效率和用户体验。本文将介绍RESTful API的基本原则及其在Python中的实现方法。以Flask为例,演示了如何通过不同的HTTP方法(如GET、POST、PUT、DELETE)来创建、读取、更新和删除用户信息。此示例还包括了基本的路由设置及操作,为开发者提供了清晰的API交互指南。
55 6
|
2月前
|
存储 JSON API
淘系API接口(解析返回的json数据)商品详情数据解析助力开发者
——在成长的路上,我们都是同行者。这篇关于商品详情API接口的文章,希望能帮助到您。期待与您继续分享更多API接口的知识,请记得关注Anzexi58哦! 淘宝API接口(如淘宝开放平台提供的API)允许开发者获取淘宝商品的各种信息,包括商品详情。然而,需要注意的是,直接访问淘宝的商品数据API通常需要商家身份或开发者权限,并且需要遵循淘宝的API使用协议。
淘系API接口(解析返回的json数据)商品详情数据解析助力开发者
|
2月前
|
SQL 存储 数据处理
下一篇
无影云桌面