JS在线运行

版本:

所属目录
点击了解高性能代码运行API
运行结果
教程手册
代码仓库
极速运行
终端运行
图形+终端

                        
以下是用户最新保存的代码
<h1>this指向知识点 发布于:2025-07-01 16:07 <h1> sort的使用 发布于:2025-07-01 14:35 <h1> slice的使用 发布于:2025-07-01 14:31 <h1> shift的使用 发布于:2025-07-01 14:27 <h1> push的使用 发布于:2025-07-01 14:21 <h1> join的补充与pop的使用 发布于:2025-07-01 14:17 <h1> split与join的使用 发布于:2025-07-01 14:09 <h1> concat的使用 发布于:2025-07-01 11:52 <h1> indexOf的使用 发布于:2025-07-01 11:48 <h1> forEach的使用 发布于:2025-07-01 11:42 <h1> filter的使用 发布于:2025-07-01 11:25 <h1> some使用 发布于:2025-07-01 11:20 <h1> every使用 发布于:2025-07-01 11:16 <h1> reduce使用 发布于:2025-07-01 11:08 <h1> 数组 发布于:2025-07-01 11:05 <h1> 箭头函数 发布于:2025-07-01 10:53 <h1>数组方法 发布于:2025-07-01 11:52 <h1>箭头函数与...rest的结合 发布于:2025-07-01 10:24 <h1>箭头函数知识点 发布于:2025-07-01 10:19 js base64 发布于:2025-06-28 01:16 栅格化所有形状图层 发布于:2025-06-01 16:20 雪花算法ID 发布于:2025-05-30 13:59 Create a new reservation balalal 发布于:2025-06-28 18:44 Main message loop 发布于:2025-05-28 09:33 .env 发布于:2025-05-27 22:57 logger.js 发布于:2025-05-27 22:56 api.js 发布于:2025-05-27 22:56 SchedulerService.js 发布于:2025-05-27 22:55 WebhookService.js 发布于:2025-05-27 22:55 WeChatService.js 发布于:2025-05-27 22:54 database.js 发布于:2025-05-27 22:54 server.js 发布于:2025-05-27 22:53 package.json 发布于:2025-05-27 22:52 suzhou inovance shanglvlianmeng 发布于:2025-06-04 19:05 CryptoJS-node 发布于:2025-05-23 13:51 Promise链式调用示例 发布于:2025-05-21 19:40 扁平化JSON数据 发布于:2025-05-13 16:18 // 1. 粘贴你的原始 JSON 字符串 let raw = `{ "10": { "upgrade": 0 }, "15": { "upgrade": 3 }, "20": { "upgrade": 4 } }`; // 2. 解析为对象 let data = JSON.parse(raw); // 3. 批量处理 upgrade 字段 for (let k in data) { if (data[k].upgrade !== undefined) { data[k].upgrade = Math.floor(data[k].upgrade / 2); // 向下取整 } } // 4. 输出新 JSON 字符串 console.log(JSON.stringify(data, null, 2)); 发布于:2025-05-13 10:39 AES加解密 发布于:2025-05-08 13:31 ceshi damai 发布于:2025-05-06 22:53 新编写的企划内容 发布于:2025-04-30 20:25 JavaScript脚本与MongoDB服务器交互 发布于:2025-04-30 14:09 临时使用代码 发布于:2025-04-29 20:00 - 统计数组里最多的元素,并排序 - 构建树形结构并进行后续遍历 发布于:2025-06-05 15:27 手写防抖和节流 发布于:2025-05-16 16:58 check in balalal 发布于:2025-05-25 11:42 最近一次给学姐的代码 发布于:2025-04-26 13:13 JS AES128加解密 发布于:2025-04-21 13:44 最小矩阵宽度(从第一列开始一列列加,直到判断子矩阵内包含数组的所有元素) 发布于:2025-04-16 19:10 最小交付时间(二分+回溯:先将数组排序,最小值start=Math.max(arr),最大值end = arr.reduce,回溯中创建一个新的工人数组,每次遍历数组时将数组中的每一个元素都尝试分配给worker[i]) 发布于:2025-04-16 18:53 [更多]
显示目录

实用工具



学习嵌入式的绝佳套件,esp8266开源小电视成品,比自己去买开发板+屏幕还要便宜,省去了焊接不当搞坏的风险。 蜂鸣版+触控升级仅36元,更强的硬件、价格全网最低。

点击购买 固件广场

实用工具

稳定性: 4 - 锁定

本节介绍Node.js的'util'模块中的函数的使用,通过require('util')访问该模块,如下所示:

const util = require('util');

util 模块原先设计的初衷是用来支持Node.js的内部API的。这里的很多的函数对你的程序来说都非常有用。如果你觉得这些函数不能满足你的要求,那你可以写自己的工具函数。我们不希望'util'模块里添加对于node内部函数无用的扩展。

util.debuglog(section)

  • section{字符串} 被调试的程序节点部分
  • Returns: {Function} 日志函数

用来创建一个有条件的写到stderr的函数(基于NODE_DEBUG环境变量)。如果section出现在环境变量里,返回函数将会和console.error()类似。否则,返回一个空函数。

例如:

var debuglog = util.debuglog('foo');

var bar = 123;
debuglog('hello from foo [%d]', bar);

如果这个程序以NODE_DEBUG=foo的环境运行,将会输出:

FOO 3245: hello from foo [123]

3245是进程ID。如果没有运行在这个环境变量里,将不会打印任何东西。

可以用逗号切割多个NODE_DEBUG环境变量。例如:NODE_DEBUG=fs,net,tls

util.format(format[, ...])

使用第一个参数返回一个格式化的字符串,类似printf

第一个参数是字符串,它包含0或更多的占位符。每个占位符被替换成想要参数转换的值。支持的占位符包括:

  • %s- 字符串.
  • %d- 数字 (整数和浮点数).
  • %j- JSON。如果参数包含循环引用,将会用字符串替换R
  • %%- 单独一个百分号 ('%')。 不会消耗一个参数。

如果占位符没有包含一个相应的参数,占位符不会被替换。

util.format('%s:%s', 'foo'); // 'foo:%s'

如果参数超过占位符,多余的参数将会用util.inspect()转换成字符串,并拼接在一起,用空格隔开。

util.format('%s:%s', 'foo', 'bar', 'baz'); // 'foo:bar baz'

如果第一个参数不是格式化字符串,那么util.format()会返回所有参数拼接成的字符串(空格分割)。每个参数都会用util.inspect()转换成字符串。

util.format(1, 2, 3); // '1 2 3'

util.log(string)

stdout输出并带有时间戳:

require('util').log('Timestamped message.');

util.inspect(object[, options])

返回一个对象的字符串表现形式,在代码调试的时候非常有用。

通过加入一些可选选项,来改变对象的格式化输出形式:

  • showHidden- 如果为true,将会显示对象的不可枚举属性。默认为false

  • depth- 告诉inspect格式化对象时递归多少次。这在格式化大且复杂对象时非常有用。默认为 2。如果想无穷递归的话,传null

  • colors- 如果为true,输出内容将会格式化为有颜色的代码。默认为false, 颜色可以自定义,参见下文。

  • customInspect- 如果为false,那么定义在被检查对象上的inspect(depth, opts) 方法将不会被调用。 默认为true。

检查util对象上所有属性的例子:

var util = require('util');

console.log(util.inspect(util, { showHidden: true, depth: null }));

当被调用的时候,参数值可以提供自己的自定义inspect(depth, opts)方法。该方法会接收当前的递归检查深度,以及传入util.inspect()的其他参数。

自定义util.inspect颜色

util.inspect通过util.inspect.stylesutil.inspect.colors对象,自定义全局的输出颜色,

util.inspect.stylesutil.inspect.colors组成风格颜色的一对映射。

高亮风格和他们的默认值:

  • 数字 (黄色)
  • boolean (黄色)
  • 字符串 (绿色)
  • date (洋红)
  • regexp (红色)
  • null (粗体)
  • undefined (斜体)
  • special (青绿色)
  • name (内部用,不是风格)

预定义的颜色为: white斜体blackbluecyan绿色洋红红色黄色以及粗体斜体下划线反选风格。

对象上德自定义inspect()函数

对象也能自定义inspect(depth)函数, 当使用util.inspect()检查该对象的时候,将会执行对象自定义的检查方法:

var util = require('util');

var obj = { name: 'nate' };
obj.inspect = function(depth) {
  return '{' + this.name + '}';
};

util.inspect(obj);
  // "{nate}"

你可以返回另外一个对象,返回的字符串会根据返回的对象格式化这和JSON.stringify()的工作流程类似。您还可以完全返回另一个对象,返回的字符串将根据返回的对象格式化。这与JSON.stringify()的工作方式类似:

var obj = { foo: 'this will not show up in the inspect() output' };
obj.inspect = function(depth) {
  return { bar: 'baz' };
};

util.inspect(obj);
  // "{ bar: 'baz' }"

util.isArray(object)

Array.isArray的内部别名。

如果参数"object"是数组,返回true ,否则返回false

var util = require('util');

util.isArray([])
  // true
util.isArray(new Array)
  // true
util.isArray({})
  // false

util.isRegExp(object)

如果参数"object"是RegExp返回true ,否则返回false

var util = require('util');

util.isRegExp(/some regexp/)
  // true
util.isRegExp(new RegExp('another regexp'))
  // true
util.isRegExp({})
  // false

util.isDate(object)

如果参数"object"是Date返回true,否则返回false

var util = require('util');

util.isDate(new Date())
  // true
util.isDate(Date())
  // false (without 'new' returns a String)
util.isDate({})
  // false

util.isError(object)

如果参数"object"是Error返回true,否则返回false

var util = require('util');

util.isError(new Error())
  // true
util.isError(new TypeError())
  // true
util.isError({ name: 'Error', message: 'an error occurred' })
  // false

util.inherits(constructor, superConstructor)

从一个构造函数constructor继承原型方法到另一个。构造函数的原型将被设置为一个新的从超类(superConstructor)创建的对象。

通过constructor.super_属性可以访问superConstructor

var util = require("util");
var events = require("events");

function MyStream() {
    events.EventEmitter.call(this);
}

util.inherits(MyStream, events.EventEmitter);

MyStream.prototype.write = function(data) {
    this.emit("data", data);
}

var stream = new MyStream();

console.log(stream instanceof events.EventEmitter); // true
console.log(MyStream.super_ === events.EventEmitter); // true

stream.on("data", function(data) {
    console.log('Received data: "' + data + '"');
})
stream.write("It works!"); // Received data: "It works!"

util.deprecate(function, string)

标明该方法不要再使用。

exports.puts = exports.deprecate(function() {
  for (var i = 0, len = arguments.length; i < len; ++i) {
    process.stdout.write(arguments[i] + '\n');
  }
}, 'util.puts: Use console.log instead')

返回一个修改过的函数,默认情况下仅警告一次。如果设置了--no-deprecation该函数不做任何事。如果设置了--throw-deprecation,如果使用了该API应用将会抛出异常。

util.debug(string)

稳定性: 0 - 抛弃: 使用 console.error() 替换。

console.error的前身。

util.error([...])

稳定性: 0 - 抛弃: 使用 console.error() 替换。

console.error的前身。

util.puts([...])

稳定性: 0 - 抛弃:使用 console.log() 替换。

console.log的前身。

util.print([...])

稳定性: 0 - 抛弃: 使用 console.log() 替换。

console.log的前身。

util.pump(readableStream, writableStream[, callback])

稳定性: 0 - 抛弃: Use readableStream.pipe(writableStream)

stream.pipe的前身。

由JSRUN为你提供的JS在线运行、在线编译工具
        JSRUN提供的JS 在线运行,JS 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。
yout