Перейти к содержанию

Утилиты

v18.x.x

Стабильность: 2 – Стабильная

АПИ является удовлетворительным. Совместимость с NPM имеет высший приоритет и не будет нарушена кроме случаев явной необходимости.

Модуль node:util поддерживает потребности внутренних API Node.js. Многие из утилит полезны и для разработчиков приложений и модулей. Чтобы получить к нему доступ:

1
const util = require('node:util');

util.callbackify(original)

  • original <Function> Функция async.
  • Возвращает: <Function> функцию в стиле обратного вызова

Принимает функцию async (или функцию, возвращающую Promise) и возвращает функцию в стиле обратного вызова по ошибке, т.е. принимая в качестве последнего аргумента обратный вызов (err, value) => .... В обратном вызове первым аргументом будет причина отказа (или null, если Promise разрешилась), а вторым аргументом будет разрешенное значение.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
const util = require('node:util');

async function fn() {
    return 'hello world';
}
const callbackFunction = util.callbackify(fn);

callbackFunction((err, ret) => {
    if (err) throw err;
    console.log(ret);
});

Будет печататься:

1
hello world

Обратный вызов выполняется асинхронно и имеет ограниченный стек-трейс. Если обратный вызов отбрасывается, процесс выдает событие 'uncaughtException', и, если оно не обработано, завершается.

Поскольку null имеет особое значение в качестве первого аргумента обратного вызова, если обернутая функция отклоняет Promise с ложным значением в качестве причины, значение обертывается в Error с сохранением исходного значения в поле с именем reason.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
function fn() {
    return Promise.reject(null);
}
const callbackFunction = util.callbackify(fn);

callbackFunction((err, ret) => {
    // When the Promise was rejected with `null` it is wrapped with an Error and
    // the original value is stored in `reason`.
    err &&
        Object.hasOwn(err, 'reason') &&
        err.reason === null; // true
});

util.debuglog(section[, callback]).

  • section <string> Строка, идентифицирующая часть приложения, для которой создается функция debuglog.
  • callback <Function> Обратный вызов, вызываемый при первом вызове функции логирования с аргументом функции, который является более оптимизированной функцией логирования.
  • Возвращает: <Function> Функция протоколирования.

Метод util.debuglog() используется для создания функции, которая условно записывает отладочные сообщения в stderr на основе существования переменной окружения NODE_DEBUG. Если имя section встречается в значении этой переменной окружения, то возвращаемая функция работает аналогично console.error(). Если нет, то возвращаемая функция не работает.

1
2
3
4
const util = require('node:util');
const debuglog = util.debuglog('foo');

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

Если эту программу запустить с NODE_DEBUG=foo в окружении, то она выдаст что-то вроде:

1
FOO 3245: hello from foo [123]

где 3245 - идентификатор процесса. Если программа не запущена с установленной переменной окружения, то она ничего не выведет.

Секция section также поддерживает подстановочный знак:

1
2
3
4
const util = require('node:util');
const debuglog = util.debuglog('foo-bar');

debuglog("hi there, it's foo-bar [%d]", 2333);

если его запустить с NODE_DEBUG=foo* в окружении, то он выдаст что-то вроде:

1
FOO-BAR 3257: hi there, it's foo-bar [2333]

В переменной окружения NODE_DEBUG можно указать несколько имен section, разделенных запятыми: NODE_DEBUG=fs,net,tls.

Необязательный аргумент callback может быть использован для замены функции протоколирования другой функцией, не имеющей инициализации или ненужной обертки.

1
2
3
4
5
6
const util = require('node:util');
let debuglog = util.debuglog('internals', (debug) => {
    // Replace with a logging function that optimizes out
    // testing if the section is enabled
    debuglog = debug;
});

debuglog().enabled

Геттер util.debuglog().enabled используется для создания теста, который может быть использован в условиях, основанных на существовании переменной окружения NODE_DEBUG. Если имя section встречается в значении этой переменной окружения, то возвращаемое значение будет true. Если нет, то возвращаемое значение будет false.

1
2
3
4
5
const util = require('node:util');
const enabled = util.debuglog('foo').enabled;
if (enabled) {
    console.log('hello from foo [%d]', 123);
}

Если эту программу запустить с NODE_DEBUG=foo в окружении, то она выдаст что-то вроде:

1
hello from foo [123]

util.debug(section).

Псевдоним для util.debuglog. Использование позволяет читать то, что не подразумевает ведение журнала при использовании только util.debuglog().enabled.

util.deprecate(fn, msg[, code]).

  • fn <Function> Функция, которая устаревает.
  • msg <string> Предупреждающее сообщение, которое будет отображаться при вызове устаревшей функции.
  • code <string> Код устаревания.
  • Возвращает: <Function> Устаревшая функция, обернутая для выдачи предупреждения.

Метод util.deprecate() оборачивает fn (которая может быть функцией или классом) таким образом, что она помечается как устаревшая.

1
2
3
4
5
const util = require('node:util');

exports.obsoleteFunction = util.deprecate(() => {
    // Do something here.
}, 'obsoleteFunction() is deprecated. Use newShinyFunction() instead.');

При вызове util.deprecate() возвращает функцию, которая выдает DeprecationWarning, используя событие 'warning'. Предупреждение будет выдано и выведено в stderr при первом вызове возвращаемой функции. После того, как предупреждение будет выдано, обернутая функция будет вызвана без выдачи предупреждения.

Если в нескольких вызовах util.deprecate() указан один и тот же необязательный code, предупреждение будет выдано только один раз для этого code.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
const util = require('node:util');

const fn1 = util.deprecate(
    someFunction,
    someMessage,
    'DEP0001'
);
const fn2 = util.deprecate(
    someOtherFunction,
    someOtherMessage,
    'DEP0001'
);
fn1(); // Emits a deprecation warning with code DEP0001
fn2(); // Does not emit a deprecation warning because it has the same code

Если используются флаги командной строки --no-deprecation или --no-warnings, или если свойство process.noDeprecation установлено в true до первого предупреждения об износе, метод util.deprecate() ничего не делает.

Если установлены флаги командной строки --trace-deprecation или --trace-warnings, или свойство process.traceDeprecation установлено в true, предупреждение и трассировка стека печатаются в stderr при первом вызове обесценивающейся функции.

Если установлен флаг командной строки --throw-deprecation или свойство process.throwDeprecation установлено в true, то при вызове устаревшей функции будет вызвано исключение.

Флаг командной строки --throw-deprecation и свойство process.throwDeprecation имеют приоритет над --trace-deprecation и process.traceDeprecation.

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

  • format <string> Строка формата, подобная printf.

Метод util.format() возвращает отформатированную строку, используя первый аргумент как printf-подобную строку формата, которая может содержать ноль или более спецификаторов формата. Каждый спецификатор заменяется преобразованным значением соответствующего аргумента. Поддерживаются следующие спецификаторы:

  • %s: String будет использоваться для преобразования всех значений, кроме BigInt, Object и -0. Значения BigInt будут представлены символом n, а Объекты, не имеющие определенной пользователем функции toString, проверяются с помощью util.inspect() с опциями { depth: 0, colors: false, compact: 3 }.
  • %d: Number будет использоваться для преобразования всех значений, кроме BigInt и Symbol.
  • %i: parseInt(value, 10) используется для всех значений, кроме BigInt и Symbol.
  • %f: parseFloat(value) используется для всех значений, кроме Symbol.
  • %j: JSON. Заменяется строкой '[Circular]', если аргумент содержит круговые ссылки.
  • %o: Object. Строковое представление объекта с общим форматированием объектов JavaScript. Аналогично util.inspect() с опциями { showHidden: true, showProxy: true }. Это покажет полный объект, включая неперечисляемые свойства и прокси.
  • %O: Object. Строковое представление объекта с общим форматированием объекта JavaScript. Аналогично util.inspect() без опций. Будет показан полный объект, не включая неперечисляемые свойства и прокси.
  • %c: CSS. Этот спецификатор игнорируется и пропускает все переданные CSS.
  • %%: одиночный знак процента ('%'). Аргумент не используется.
  • Возвращает: <string> форматированная строка.

Если спецификатор не имеет соответствующего аргумента, он не заменяется:

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

Значения, не являющиеся частью строки формата, форматируются с помощью util.inspect(), если их тип не string.

Если в метод util.format() передано больше аргументов, чем количество спецификаторов, дополнительные аргументы конкатенируются в возвращаемую строку, разделяясь пробелами:

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

Если первый аргумент не содержит допустимого спецификатора формата, util.format() возвращает строку, которая является конкатенацией всех аргументов, разделенных пробелами:

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

Если в util.format() передан только один аргумент, он возвращается в исходном виде без какого-либо форматирования:

1
2
util.format('%% %s');
// Returns: '%% %s'

util.format() - это синхронный метод, который предназначен для отладки. Некоторые входные значения могут иметь значительный перерасход производительности, который может заблокировать цикл событий. Используйте эту функцию с осторожностью и никогда в горячем пути кода.

util.formatWithOptions(inspectOptions, format[, ...args]).

Эта функция идентична util.format(), за исключением того, что она принимает аргумент inspectOptions, который определяет опции, передаваемые util.inspect().

1
2
3
4
5
util.formatWithOptions({ colors: true }, 'See object %O', {
    foo: 42,
});
// Returns 'See object { foo: 42 }', where `42` is colored as a number
// when printed to a terminal.

util.getSystemErrorName(err)

Возвращает строковое имя для числового кода ошибки, который поступает из API Node.js. Сопоставление между кодами ошибок и именами ошибок зависит от платформы. Имена распространенных ошибок см. в Common System Errors.

1
2
3
4
fs.access('file/that/does/not/exist', (err) => {
    const name = util.getSystemErrorName(err.errno);
    console.error(name); // ENOENT
});

util.getSystemErrorMap().

  • Возвращает: {Map}

Возвращает карту всех кодов системных ошибок, доступных из API Node.js. Сопоставление между кодами ошибок и именами ошибок зависит от платформы. Имена распространенных ошибок см. в Common System Errors.

1
2
3
4
5
fs.access('file/that/does/not/exist', (err) => {
    const errorMap = util.getSystemErrorMap();
    const name = errorMap.get(err.errno);
    console.error(name); // ENOENT
});

util.inherits(constructor, superConstructor)

Стабильность: 3 – Закрыто

Наследие: Используйте синтаксис классов ES2015 и ключевое слово extends вместо этого.

Использование util.inherits() не рекомендуется. Пожалуйста, используйте ключевые слова ES6 class и extends, чтобы получить поддержку наследования на уровне языка. Также обратите внимание, что эти два стиля семантически несовместимы.

Наследуйте методы прототипа из одного конструктора в другой. Прототип constructor будет установлен на новый объект, созданный из superConstructor.

Это в основном добавляет некоторую проверку ввода поверх Object.setPrototypeOf(constructor.prototype, superConstructor.prototype). В качестве дополнительного удобства, superConstructor будет доступен через свойство constructor.super_.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
const util = require('node:util');
const EventEmitter = require('node:events');

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

util.inherits(MyStream, EventEmitter);

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

const stream = new MyStream();

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

stream.on('data', (data) => {
    console.log(`Received data: "${data}"`);
});
stream.write('It works!'); // Received data: "It works!"

Пример ES6 с использованием class и extends:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
const EventEmitter = require('node:events');

class MyStream extends EventEmitter {
    write(data) {
        this.emit('data', data);
    }
}

const stream = new MyStream();

stream.on('data', (data) => {
    console.log(`Received data: "${data}"`);
});
stream.write('With ES6');

util.inspect(object[, options])

util.inspect(object[, showHidden[, depth[, colors]]]).

  • object <any> Любой примитив JavaScript или Object.
  • options <Object>
    • showHidden <boolean> Если true, то неперечисляемые символы и свойства объекта будут включены в отформатированный результат. Также включаются записи WeakMap и WeakSet, а также определяемые пользователем свойства прототипа (за исключением свойств метода). По умолчанию: false.
    • depth <number> Определяет количество раз для перебора при форматировании объекта. Это полезно для проверки больших объектов. Для вызова до максимального размера стека вызовов передайте Infinity или null. По умолчанию: 2.
    • colors <boolean> Если true, вывод будет оформлен с использованием цветовых кодов ANSI. Цвета можно настраивать. Смотрите Настройка цветов util.inspect. По умолчанию: false.
    • customInspect <boolean>. Если false, то функции [util.inspect.custom](depth, opts, inspect) не вызываются. По умолчанию: true.
    • showProxy <boolean> Если true, то проверка Proxy включает объекты target и handler. По умолчанию: false.
    • maxArrayLength <integer> Определяет максимальное количество элементов Array, TypedArray, Map, Set, WeakMap и WeakSet, которые следует включать при форматировании. Установите значение null или Infinity, чтобы показать все элементы. Установите значение 0 или отрицательное, чтобы не показывать никаких элементов. По умолчанию: 100.
    • maxStringLength <integer> Определяет максимальное количество символов для включения при форматировании. Установите значение null или бесконечность, чтобы показать все элементы. Установите 0 или отрицательное значение, чтобы не показывать никаких символов. По умолчанию: 10000.
    • breakLength <integer> Длина, при которой вводимые значения разбиваются на несколько строк. Установите значение Infinity для форматирования ввода в виде одной строки (в сочетании с compact, установленным в true или любым числом >= 1). По умолчанию: 80.
    • compact {boolean|integer} Установка этого параметра в false приводит к тому, что каждый ключ объекта будет отображаться на новой строке. Текст, длина которого превышает breakLength, будет обрываться на новых строках. Если задано число, то наиболее n внутренних элементов объединяются на одной строке, пока все свойства помещаются в breakLength. Короткие элементы массива также группируются вместе. F
1
2
3
  - `sorted` {boolean|Function} Если установлено значение `true` или функция, все свойства объекта, а также записи `Set` и `Map` сортируются в результирующей строке. Если установлено значение `true`, то используется [сортировка по умолчанию](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort). Если задана функция, то она используется как [функция сравнения](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#Parameters).
  - `getters` {boolean|string} Если установлено значение `true`, проверяются геттеры. Если установлено значение `'get'`, проверяются только геттеры без соответствующего сеттера. Если установлено значение `'set'`, проверяются только геттеры с соответствующим сеттером. Это может вызвать побочные эффекты в зависимости от функции getter. **По умолчанию:** `false`.
  - `numericSeparator` {boolean} Если установлено значение `true`, то подчеркивание используется для разделения каждых трех цифр во всех bigint и числах. **По умолчанию:** `false`.
  • Возвращает: <string> Представление объекта.

Метод util.inspect() возвращает строковое представление объекта, предназначенное для отладки. Вывод util.inspect может измениться в любой момент и не должен зависеть от него программно. Могут быть переданы дополнительные опции, которые изменяют результат. util.inspect() будет использовать имя конструктора и/или @@toStringTag для создания идентифицируемой метки для проверяемого значения.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
class Foo {
    get [Symbol.toStringTag]() {
        return 'bar';
    }
}

class Bar {}

const baz = Object.create(null, {
    [Symbol.toStringTag]: { value: 'foo' },
});

util.inspect(new Foo()); // 'Foo [bar] {}'
util.inspect(new Bar()); // 'Bar {}'
util.inspect(baz); // '[foo] {}'

Циркулярные ссылки указывают на свой якорь с помощью ссылочного индекса:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
const { inspect } = require('node:util');

const obj = {};
obj.a = [obj];
obj.b = {};
obj.b.inner = obj.b;
obj.b.obj = obj;

console.log(inspect(obj));
// <ref *1> {
//   a: [ [Circular *1] ],
//   b: <ref *2> { inner: [Circular *2], obj: [Circular *1] }
// }

В следующем примере проверяются все свойства объекта util:

1
2
3
4
5
const util = require('node:util');

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

В следующем примере показан эффект опции compact:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
const util = require('node:util');

const o = {
    a: [
        1,
        2,
        [
            [
                'Lorem ipsum dolor sit amet,\nconsectetur adipiscing elit, sed do ' +
                    'eiusmod \ntempor incididunt ut labore et dolore magna aliqua.',
                'test',
                'foo',
            ],
        ],
        4,
    ],
    b: new Map([
        ['za', 1],
        ['zb', 'test'],
    ]),
};
console.log(
    util.inspect(o, {
        compact: true,
        depth: 5,
        breakLength: 80,
    })
);

// { a:
//   [ 1,
//     2,
//     [ [ 'Lorem ipsum dolor sit amet,\nconsectetur [...]', // A long line
//           'test',
//           'foo' ] ],
//     4 ],
//   b: Map(2) { 'za' => 1, 'zb' => 'test' } }

// Setting `compact` to false or an integer creates more reader friendly output.
console.log(
    util.inspect(o, {
        compact: false,
        depth: 5,
        breakLength: 80,
    })
);

// {
//   a: [
//     1,
//     2,
//     [
//       [
//         'Lorem ipsum dolor sit amet,\n' +
//           'consectetur adipiscing elit, sed do eiusmod \n' +
//           'tempor incididunt ut labore et dolore magna aliqua.',
//         'test',
//         'foo'
//       ]
//     ],
//     4
//   ],
//   b: Map(2) {
//     'za' => 1,
//     'zb' => 'test'
//   }
// }

// Setting `breakLength` to e.g. 150 will print the "Lorem ipsum" text in a
// single line.

Опция showHidden позволяет просматривать записи WeakMap и WeakSet. Если записей больше, чем maxArrayLength, то нет гарантии, какие записи будут отображены. Это означает, что получение одних и тех же записей WeakSet дважды может привести к разным результатам. Более того, записи, в которых не осталось сильных ссылок, могут быть собраны в мусор в любое время.

1
2
3
4
5
6
7
8
const { inspect } = require('node:util');

const obj = { a: 1 };
const obj2 = { b: 2 };
const weakSet = new WeakSet([obj, obj2]);

console.log(inspect(weakSet, { showHidden: true }));
// WeakSet { { a: 1 }, { b: 2 } }

Опция sorted гарантирует, что порядок вставки свойств объекта не повлияет на результат работыutil.inspect()`.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
const { inspect } = require('node:util');
const assert = require('node:assert');

const o1 = {
    b: [2, 3, 1],
    a: '`a` comes before `b`',
    c: new Set([2, 3, 1]),
};
console.log(inspect(o1, { sorted: true }));
// { a: '`a` comes before `b`', b: [ 2, 3, 1 ], c: Set(3) { 1, 2, 3 } }
console.log(
    inspect(o1, { sorted: (a, b) => b.localeCompare(a) })
);
// { c: Set(3) { 3, 2, 1 }, b: [ 2, 3, 1 ], a: '`a` comes before `b`' }

const o2 = {
    c: new Set([2, 1, 3]),
    a: '`a` comes before `b`',
    b: [2, 3, 1],
};
assert.strict.equal(
    inspect(o1, { sorted: true }),
    inspect(o2, { sorted: true })
);

Опция numericSeparator добавляет ко всем числам подчеркивание через каждые три цифры.

1
2
3
4
5
6
7
8
9
const { inspect } = require('node:util');

const thousand = 1_000;
const million = 1_000_000;
const bigNumber = 123_456_789n;
const bigDecimal = 1_234.123_45;

console.log(thousand, million, bigNumber, bigDecimal);
// 1_000 1_000_000 123_456_789n 1_234.123_45

util.inspect() - это синхронный метод, предназначенный для отладки. Его максимальная длина выходных данных составляет приблизительно 128 МиБ. Вводы, которые приводят к более длинному выводу, будут усечены.

Настройка цветов util.inspect.

Вывод цвета (если он включен) в util.inspect настраивается глобально через свойства util.inspect.styles и util.inspect.colors.

util.inspect.styles - это карта, связывающая имя стиля с цветом из util.inspect.colors.

По умолчанию используются следующие стили и связанные с ними цвета:

  • bigint: yellow.
  • булево: желтый
  • дата: маджента.
  • модуль: андерлайн
  • имя: (без стилизации)
  • null: жирный
  • число: желтый
  • regexp: red
  • специальный: синий (например, Proxies)
  • строка: зеленый
  • символ: зеленый
  • неопределенный: серый

Цветовая стилизация использует управляющие коды ANSI, которые могут поддерживаться не на всех терминалах. Для проверки поддержки цветов используйте tty.hasColors().

Ниже перечислены предопределенные управляющие коды (сгруппированные как "Модификаторы", "Цвета переднего плана" и "Цвета заднего плана").

Модификаторы

Modifier support varies throughout different terminals. They will mostly be ignored, if not supported.

  • reset - Resets all (color) modifiers to their defaults
  • bold - Make text bold
  • italic - Make text italic
  • underline - Make text underlined
  • strikethrough - Puts a horizontal line through the center of the text (Alias: strikeThrough, crossedout, crossedOut)
  • hidden - Prints the text, but makes it invisible (Alias: conceal)
  • dim - Decreased color intensity (Alias: faint)
  • overlined - Make text overlined
  • blink - Hides and shows the text in an interval
  • inverse - Swap foreground and background colors (Alias: swapcolors, swapColors)
  • doubleunderline - Make text double underlined (Alias: doubleUnderline)
  • framed - Draw a frame around the text

Цвета переднего плана

  • черный
  • красный
  • зелёный
  • жёлтый
  • синий
  • маджента
  • циан
  • белый
  • серый (псевдонимы: grey, blackBright)
  • redBright
  • зеленый
  • желто-светлый
  • blueBright
  • magentaBright
  • cyanBright
  • белый

Фоновые цвета

  • bgBlack
  • bgRed
  • bgGreen
  • bgYellow
  • bgBlue
  • bgMagenta
  • bgCyan
  • bgWhite
  • bgGray (псевдонимы: bgGrey, bgBlackBright)
  • bgRedBright
  • bgGreenBright
  • bgYellowBright
  • bgBlueBright
  • bgMagentaBright
  • bgCyanBright
  • bgWhiteBright

Пользовательские функции проверки объектов

Объекты могут также определять свои собственные [util.inspect.custom](depth, opts, inspect) функции, которые util.inspect() будет вызывать и использовать результат при инспектировании объекта.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
const util = require('node:util');

class Box {
    constructor(value) {
        this.value = value;
    }

    [util.inspect.custom](depth, options, inspect) {
        if (depth < 0) {
            return options.stylize('[Box]', 'special');
        }

        const newOptions = Object.assign({}, options, {
            depth:
                options.depth === null
                    ? null
                    : options.depth - 1,
        });

        // Five space padding because that's the size of "Box< ".
        const padding = ' '.repeat(5);
        const inner = inspect(
            this.value,
            newOptions
        ).replace(/\n/g, `\n${padding}`);
        return `${options.stylize(
            'Box',
            'special'
        )}< ${inner} >`;
    }
}

const box = new Box(true);

util.inspect(box);
// Returns: "Box< true >"

Пользовательские функции [util.inspect.custom](depth, opts, inspect) обычно возвращают строку, но могут возвращать значение любого типа, которое будет соответствующим образом отформатировано util.inspect().

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
const util = require('node:util');

const obj = {
    foo: 'this will not show up in the inspect() output',
};
obj[util.inspect.custom] = (depth) => {
    return { bar: 'baz' };
};

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

util.inspect.custom

  • {символ}, который можно использовать для объявления пользовательских функций inspect.

Помимо того, что этот символ доступен через util.inspect.custom, он зарегистрирован глобально и может быть доступен в любой среде как Symbol.for('nodejs.util.inspect.custom').

Использование этого позволяет писать переносимый код, так что пользовательская функция inspect используется в среде Node.js и игнорируется в браузере. Сама функция util.inspect() передается в качестве третьего аргумента в пользовательскую функцию inspect, чтобы обеспечить дальнейшую переносимость.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
const customInspectSymbol = Symbol.for(
    'nodejs.util.inspect.custom'
);

class Password {
    constructor(value) {
        this.value = value;
    }

    toString() {
        return 'xxxxxxxx';
    }

    [customInspectSymbol](depth, inspectOptions, inspect) {
        return `Password <${this.toString()}>`;
    }
}

const password = new Password('r0sebud');
console.log(password);
// Prints Password <xxxxxxxx>

Более подробную информацию смотрите в разделе Пользовательские функции проверки объектов.

util.inspect.defaultOptions.

Значение defaultOptions позволяет настраивать параметры по умолчанию, используемые util.inspect. Это полезно для таких функций, как console.log или util.format, которые неявно вызывают util.inspect. Он должен быть установлен в объект, содержащий одну или несколько допустимых опций util.inspect(). Также поддерживается непосредственная установка свойств опций.

1
2
3
4
5
6
const util = require('node:util');
const arr = Array(101).fill(0);

console.log(arr); // Logs the truncated array
util.inspect.defaultOptions.maxArrayLength = null;
console.log(arr); // logs the full array

util.isDeepStrictEqual(val1, val2)

Возвращает true, если существует глубокое строгое равенство между val1 и val2. В противном случае возвращается false.

Дополнительную информацию о глубоком строгом равенстве смотрите в assert.deepStrictEqual().

Класс: util.MIMEType

Стабильность: 1 – Экспериментальная

Экспериментальная

Реализация класса MIMEType.

В соответствии с соглашениями браузера, все свойства объектов MIMEType реализованы как геттеры и сеттеры прототипа класса, а не как свойства данных самого объекта.

MIME-строка - это структурированная строка, содержащая несколько значимых компонентов. При разборе возвращается объект MIMEType, содержащий свойства для каждого из этих компонентов.

Конструктор: new MIMEType(input)

  • input <string> Входной MIME для разбора

Создает новый объект MIMEType путем разбора input.

1
2
3
import { MIMEType } from 'node:util';

const myMIME = new MIMEType('text/plain');
1
2
3
const { MIMEType } = require('node:util');

const myMIME = new MIMEType('text/plain');

Если вход не является допустимым MIME, будет выдана ошибка TypeError. Обратите внимание, что будет предпринята попытка преобразовать заданные значения в строки. Например:

1
2
3
4
5
6
import { MIMEType } from 'node:util';
const myMIME = new MIMEType({
    toString: () => 'text/plain',
});
console.log(String(myMIME));
// Prints: text/plain
1
2
3
4
5
6
const { MIMEType } = require('node:util');
const myMIME = new MIMEType({
    toString: () => 'text/plain',
});
console.log(String(myMIME));
// Prints: text/plain

mime.type

Получает и устанавливает часть типа MIME.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
import { MIMEType } from 'node:util';

const myMIME = new MIMEType('text/javascript');
console.log(myMIME.type);
// Prints: text
myMIME.type = 'application';
console.log(myMIME.type);
// Prints: application
console.log(String(myMIME));
// Prints: application/javascript
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
const { MIMEType } = require('node:util');

const myMIME = new MIMEType('text/javascript');
console.log(myMIME.type);
// Prints: text
myMIME.type = 'application';
console.log(myMIME.type);
// Prints: application
console.log(String(myMIME));
// Prints: application/javascript

mime.subtype

Получает и устанавливает часть подтипа MIME.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
import { MIMEType } from 'node:util';

const myMIME = new MIMEType('text/ecmascript');
console.log(myMIME.subtype);
// Prints: ecmascript
myMIME.subtype = 'javascript';
console.log(myMIME.subtype);
// Prints: javascript
console.log(String(myMIME));
// Prints: text/javascript
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
const { MIMEType } = require('node:util');

const myMIME = new MIMEType('text/ecmascript');
console.log(myMIME.subtype);
// Prints: ecmascript
myMIME.subtype = 'javascript';
console.log(myMIME.subtype);
// Prints: javascript
console.log(String(myMIME));
// Prints: text/javascript

mime.essence

Получает сущность MIME. Это свойство доступно только для чтения. Используйте mime.type или mime.subtype для изменения MIME.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
import { MIMEType } from 'node:util';

const myMIME = new MIMEType('text/javascript;key=value');
console.log(myMIME.essence);
// Prints: text/javascript
myMIME.type = 'application';
console.log(myMIME.essence);
// Prints: application/javascript
console.log(String(myMIME));
// Prints: application/javascript;key=value
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
const { MIMEType } = require('node:util');

const myMIME = new MIMEType('text/javascript;key=value');
console.log(myMIME.essence);
// Prints: text/javascript
myMIME.type = 'application';
console.log(myMIME.essence);
// Prints: application/javascript
console.log(String(myMIME));
// Prints: application/javascript;key=value

mime.params

  • {MIMEParams}

Получает объект MIMEParams, представляющий параметры MIME. Это свойство доступно только для чтения. Подробности см. в документации MIMEParams.

mime.toString().

Метод toString() объекта MIMEType возвращает сериализованный MIME.

Из-за необходимости соответствия стандарту этот метод не позволяет пользователям настраивать процесс сериализации MIME.

mime.toJSON().

Псевдоним для mime.toString().

Этот метод автоматически вызывается, когда объект MIMEType сериализуется с помощью JSON.stringify().

1
2
3
4
5
6
7
8
import { MIMEType } from 'node:util';

const myMIMES = [
    new MIMEType('image/png'),
    new MIMEType('image/gif'),
];
console.log(JSON.stringify(myMIMES));
// Prints: ["image/png", "image/gif"]
1
2
3
4
5
6
7
8
const { MIMEType } = require('node:util');

const myMIMES = [
    new MIMEType('image/png'),
    new MIMEType('image/gif'),
];
console.log(JSON.stringify(myMIMES));
// Prints: ["image/png", "image/gif"]

Класс: util.MIMEParams.

API MIMEParams предоставляет доступ на чтение и запись к параметрам MIMEType.

Конструктор: new MIMEParams().

Создает новый объект MIMEParams с пустыми параметрами

1
2
3
import { MIMEParams } from 'node:util';

const myParams = new MIMEParams();
1
2
3
const { MIMEParams } = require('node:util');

const myParams = new MIMEParams();

mimeParams.delete(name).

Удаляет все пары имя-значение, имя которых равно name.

mimeParams.entries().

  • Возвращает: {Iterator}

Возвращает итератор по каждой из пар "имя-значение" в параметрах. Каждый элемент итератора представляет собой JavaScript массив. Первый элемент массива - это имя, второй элемент массива - значение.

mimeParams.get(name).

  • name <string>
  • Возвращает: <string> или null, если не существует пары имя-значение с заданным name.

Возвращает значение первой пары имя-значение, имя которой равно name. Если таких пар нет, возвращается null.

mimeParams.has(name).

Возвращает true, если существует хотя бы одна пара имя-значение, имя которой равно name.

mimeParams.keys().

Возвращает итератор по именам каждой пары имя-значение.

1
2
3
4
5
6
7
8
9
import { MIMEType } from 'node:util';

const { params } = new MIMEType('text/plain;foo=0;bar=1');
for (const name of params.keys()) {
    console.log(name);
}
// Prints:
//   foo
//   bar
1
2
3
4
5
6
7
8
9
const { MIMEType } = require('node:util');

const { params } = new MIMEType('text/plain;foo=0;bar=1');
for (const name of params.keys()) {
    console.log(name);
}
// Prints:
//   foo
//   bar

mimeParams.set(name, value).

Устанавливает значение в объекте MIMEParams, связанном с name, в value. Если существуют уже существующие пары имя-значение, имена которых равны name, установите значение первой такой пары в value.

1
2
3
4
5
6
7
import { MIMEType } from 'node:util';

const { params } = new MIMEType('text/plain;foo=0;bar=1');
params.set('foo', 'def');
params.set('baz', 'xyz');
console.log(params.toString());
// Prints: foo=def&bar=1&baz=xyz
1
2
3
4
5
6
7
const { MIMEType } = require('node:util');

const { params } = new MIMEType('text/plain;foo=0;bar=1');
params.set('foo', 'def');
params.set('baz', 'xyz');
console.log(params.toString());
// Prints: foo=def&bar=1&baz=xyz

mimeParams.values().

Возвращает итератор по значениям каждой пары имя-значение.

mimeParams[@@iterator]().

Псевдоним для mimeParams.entries().

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
import { MIMEType } from 'node:util';

const { params } = new MIMEType(
    'text/plain;foo=bar;xyz=baz'
);
for (const [name, value] of params) {
    console.log(name, value);
}
// Prints:
//   foo bar
//   xyz baz
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
const { MIMEType } = require('node:util');

const { params } = new MIMEType(
    'text/plain;foo=bar;xyz=baz'
);
for (const [name, value] of params) {
    console.log(name, value);
}
// Prints:
//   foo bar
//   xyz baz

util.parseArgs([config])

  • config <Object> Используется для предоставления аргументов для разбора и для настройки парсера. config поддерживает следующие свойства:
    • args <string[]> массив строк аргументов. По умолчанию: process.argv с удаленными execPath и filename.
    • options <Object> Используется для описания аргументов, известных синтаксическому анализатору. Ключами options являются длинные имена опций, а значениями - <Object>, принимающие следующие свойства:
      • type <string> Тип аргумента, который должен быть либо boolean, либо string.
      • multiple <boolean> Может ли этот параметр быть указан несколько раз. Если true, все значения будут собраны в массив. Если false, то значения для опции будут последними. По умолчанию: false.
      • short <string> Односимвольный псевдоним для опции.
      • default {string | boolean | string[] | boolean[]} Значение опции по умолчанию, если оно не задано args. Оно должно быть того же типа, что и свойство type. Если multiple имеет значение true, это должен быть массив.
    • strict <boolean> Должна ли возникать ошибка при встрече неизвестных аргументов или при передаче аргументов, не соответствующих типу, заданному в options. По умолчанию: true.
    • allowPositionals <boolean> Принимает ли эта команда позиционные аргументы. По умолчанию: false, если strict равно true, иначе true.
    • tokens <boolean> Возвращает разобранные лексемы. Это полезно для расширения встроенного поведения, от добавления дополнительных проверок до переработки токенов различными способами. По умолчанию: false.
  • Возвращает: <Object> Разобранные аргументы командной строки:
    • values <Object> Отображение разобранных имен опций с их значениями <string> или <boolean>.
    • positionals <string[]> Позиционные аргументы.
    • токены {Object[] | undefined} См. раздел parseArgs tokens. Возвращается только если config включает tokens: true.

Предоставляет API более высокого уровня для разбора аргументов командной строки, чем непосредственное взаимодействие с process.argv. Принимает спецификацию ожидаемых аргументов и возвращает структурированный объект с разобранными опциями и позициями.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
import { parseArgs } from 'node:util';
const args = ['-f', '--bar', 'b'];
const options = {
    foo: {
        type: 'boolean',
        short: 'f',
    },
    bar: {
        type: 'string',
    },
};
const { values, positionals } = parseArgs({
    args,
    options,
});
console.log(values, positionals);
// Prints: [Object: null prototype] { foo: true, bar: 'b' } []
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
const { parseArgs } = require('node:util');
const args = ['-f', '--bar', 'b'];
const options = {
    foo: {
        type: 'boolean',
        short: 'f',
    },
    bar: {
        type: 'string',
    },
};
const { values, positionals } = parseArgs({
    args,
    options,
});
console.log(values, positionals);
// Prints: [Object: null prototype] { foo: true, bar: 'b' } []

parseArgs tokens.

Детальная информация о разборе доступна для добавления пользовательского поведения, если указать tokens: true в конфигурации. Возвращаемые токены имеют свойства, описывающие:

  • все токены
    • kind <string> Одно из 'option', 'positional' или 'option-terminator'.
    • index <number> Индекс элемента в args, содержащего токен. Таким образом, исходным аргументом для токена является args[token.index].
  • токены опций
    • name <string> Длинное имя опции.
    • rawName <string> Как опция используется в args, например, -f из --foo.
    • value {string | undefined} Значение опции, указанное в args. Неопределено для булевых опций.
    • inlineValue {boolean | undefined} Указывается ли значение опции в строке, как --foo=bar.
  • позиционные маркеры
    • value <string> Значение позиционного аргумента в args (т.е. args[index]).
  • опция-терминатор токена

Возвращаемые лексемы располагаются в том порядке, в котором они встречаются во входных args. Опции, которые встречаются в args более одного раза, выдают маркер для каждого использования. Короткие группы опций, такие как -xy, расширяются до маркера для каждой опции. Таким образом, -xxx дает три токена.

Например, чтобы использовать возвращенные маркеры для добавления поддержки отрицаемой опции, такой как --no-color, маркеры могут быть обработаны для изменения значения, хранящегося для отрицаемой опции.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
import { parseArgs } from 'node:util';

const options = {
    color: { type: 'boolean' },
    'no-color': { type: 'boolean' },
    logfile: { type: 'string' },
    'no-logfile': { type: 'boolean' },
};
const { values, tokens } = parseArgs({
    options,
    tokens: true,
});

// Reprocess the option tokens and overwrite the returned values.
tokens
    .filter((token) => token.kind === 'option')
    .forEach((token) => {
        if (token.name.startsWith('no-')) {
            // Store foo:false for --no-foo
            const positiveName = token.name.slice(3);
            values[positiveName] = false;
            delete values[token.name];
        } else {
            // Resave value so last one wins if both --foo and --no-foo.
            values[token.name] = token.value ?? true;
        }
    });

const color = values.color;
const logfile = values.logfile ?? 'default.log';

console.log({ logfile, color });
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
const { parseArgs } = require('node:util');

const options = {
    color: { type: 'boolean' },
    'no-color': { type: 'boolean' },
    logfile: { type: 'string' },
    'no-logfile': { type: 'boolean' },
};
const { values, tokens } = parseArgs({
    options,
    tokens: true,
});

// Reprocess the option tokens and overwrite the returned values.
tokens
    .filter((token) => token.kind === 'option')
    .forEach((token) => {
        if (token.name.startsWith('no-')) {
            // Store foo:false for --no-foo
            const positiveName = token.name.slice(3);
            values[positiveName] = false;
            delete values[token.name];
        } else {
            // Resave value so last one wins if both --foo and --no-foo.
            values[token.name] = token.value ?? true;
        }
    });

const color = values.color;
const logfile = values.logfile ?? 'default.log';

console.log({ logfile, color });

Пример использования, показывающий отрицаемые варианты, и когда вариант используется несколькими способами, выигрывает последний.

1
2
3
4
5
6
7
8
$ node negate.js
{ logfile: 'default.log', color: undefined }
$ node negate.js --no-logfile --no-color
{ logfile: false, color: false }
$ node negate.js --logfile=test.log --color
{ logfile: 'test.log', color: true }
$ node negate.js --no-logfile --logfile=test.log --color --no-color
{ logfile: 'test.log', color: false }

util.promisify(original)

Принимает функцию, следуя общему стилю обратного вызова по ошибке, т.е. принимая (err, value) => ... обратный вызов в качестве последнего аргумента, и возвращает версию, которая возвращает обещания.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
const util = require('node:util');
const fs = require('node:fs');

const stat = util.promisify(fs.stat);
stat('.')
    .then((stats) => {
        // Do something with `stats`
    })
    .catch((error) => {
        // Handle the error.
    });

Или, эквивалентно, используя async function:

1
2
3
4
5
6
7
8
9
const util = require('node:util');
const fs = require('node:fs');

const stat = util.promisify(fs.stat);

async function callStat() {
    const stats = await stat('.');
    console.log(`This directory is owned by ${stats.uid}`);
}

Если присутствует свойство original[util.promisify.custom], promisify вернет его значение, см. Custom promisified functions.

promisify() предполагает, что original - это функция, принимающая обратный вызов в качестве последнего аргумента во всех случаях. Если original не является функцией, promisify() выдаст ошибку. Если original является функцией, но ее последний аргумент не является обратным вызовом с ошибкой, то в качестве последнего аргумента ей будет передан обратный вызов с ошибкой.

Использование promisify() в методах класса или других методах, использующих this, может работать не так, как ожидается, если только это не будет обработано специальным образом:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
const util = require('node:util');

class Foo {
    constructor() {
        this.a = 42;
    }

    bar(callback) {
        callback(null, this.a);
    }
}

const foo = new Foo();

const naiveBar = util.promisify(foo.bar);
// TypeError: Cannot read property 'a' of undefined
// naiveBar().then(a => console.log(a));

naiveBar.call(foo).then((a) => console.log(a)); // '42'

const bindBar = naiveBar.bind(foo);
bindBar().then((a) => console.log(a)); // '42'

Пользовательские промисифицированные функции

Используя символ util.promisify.custom, можно переопределить возвращаемое значение функции util.promisify():

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
const util = require('node:util');

function doSomething(foo, callback) {
    // ...
}

doSomething[util.promisify.custom] = (foo) => {
    return getPromiseSomehow();
};

const promisified = util.promisify(doSomething);
console.log(
    promisified === doSomething[util.promisify.custom]
);
// prints 'true'

Это может быть полезно в тех случаях, когда исходная функция не соответствует стандартному формату принятия обратного вызова, связанного с ошибкой, в качестве последнего аргумента.

Например, с функцией, принимающей (foo, onSuccessCallback, onErrorCallback):

1
2
3
4
5
doSomething[util.promisify.custom] = (foo) => {
    return new Promise((resolve, reject) => {
        doSomething(foo, resolve, reject);
    });
};

Если promisify.custom определена, но не является функцией, promisify() выдаст ошибку.

util.promisify.custom

Помимо того, что этот символ доступен через util.promisify.custom, он зарегистрирован глобально и может быть доступен в любом окружении как Symbol.for('nodejs.util.promisify.custom').

Например, с функцией, которая принимает (foo, onSuccessCallback, onErrorCallback):

1
2
3
4
5
6
7
8
9
const kCustomPromisifiedSymbol = Symbol.for(
    'nodejs.util.promisify.custom'
);

doSomething[kCustomPromisifiedSymbol] = (foo) => {
    return new Promise((resolve, reject) => {
        doSomething(foo, resolve, reject);
    });
};

util.stripVTControlCharacters(str)

Возвращает str с удаленными кодами ANSI.

1
2
3
4
console.log(
    util.stripVTControlCharacters('\u001B[4mvalue\u001B[0m')
);
// Prints "value"

Класс: util.TextDecoder.

Реализация API TextDecoder WHATWG Encoding Standard.

1
2
3
const decoder = new TextDecoder();
const u8arr = new Uint8Array([72, 101, 108, 108, 111]);
console.log(decoder.decode(u8arr)); // Hello

Поддерживаемые кодировки WHATWG

Согласно WHATWG Encoding Standard, кодировки, поддерживаемые API TextDecoder, приведены в таблицах ниже. Для каждой кодировки может использоваться один или несколько псевдонимов.

Различные конфигурации сборки Node.js поддерживают разные наборы кодировок. (см. Интернационализация)

Кодировки, поддерживаемые по умолчанию (с полными данными ICU)

Кодировка Псевдонимы
'ibm866' '866', 'cp866', 'csibm866'
'iso-8859-2' 'csisolatin2', 'iso-ir-101', 'iso8859-2', 'iso88592', 'iso_8859-2', 'iso_8859-2:1987', 'l2', 'latin2'
'iso-8859-3' 'csisolatin3', 'iso-ir-109', 'iso8859-3', 'iso88593', 'iso_8859-3', 'iso_8859-3:1988', 'l3', 'latin3'
'iso-8859-4' 'csisolatin4', 'iso-ir-110', 'iso8859-4', 'iso88594', 'iso_8859-4', 'iso_8859-4:1988', 'l4', 'latin4'
'iso-8859-5' 'csisolatincyrillic', 'cyrillic', 'iso-ir-144', 'iso8859-5', 'iso88595', 'iso_8859-5', 'iso_8859-5:1988'
iso-8859-6'` | arabic', ``asmo-708' , csiso88596e' `, csiso88596i', ``csisolatinarabic' , ecma-114' `, `iso-8859-6-e`, `iso-8859-6-i`, `iso-ir-127`, `iso8859-6`, `iso88596`, `iso_8859-6`, `iso_8859-6`,iso_8859-6: 1987'`
'iso-8859-7' 'csisolatingreek', 'ecma-118', 'elot_928', 'greek', 'greek8', 'iso-ir-126', 'iso8859-7', 'iso88597', 'iso_8859-7', 'iso_8859-7:1987', 'sun_eu_greek'
'iso-8859-8' 'csiso88598e', 'csisolatinhebrew', 'hebrew', 'iso-8859-8-e', 'iso-ir-138', 'iso8859-8', 'iso88598', 'iso_8859-8', 'iso_8859-8', 'iso_8859-8:1988', 'visual'
iso-8859-8-i'` | csiso88598i', ``логический'

| 'iso-8859-10' | 'csisolatin6', 'iso-ir-157', 'iso8859-10', 'iso885910', 'l6', 'latin6' | | | 'iso-8859-13' | 'iso8859-13', 'iso885913' | | | 'iso-8859-14' | 'iso8859-14', 'iso885914' | | | 'iso-8859-15' | 'csisolatin9', 'iso8859-15', 'iso885915', 'iso_8859-15', 'l9' | | 'koi8-r' | 'cskoi8r', 'koi', 'koi8', 'koi8_r' | | 'koi8-u' | 'koi8-ru' | | 'macintosh' | 'csmacintosh', 'mac', 'x-mac-roman' | | | | 'windows-874' | 'dos-874', 'iso-8859-11', 'iso8859-11', 'iso885911', 'tis-620' | | 'windows-1250' | 'cp1250', 'x-cp1250' | | | 'windows-1251' | 'cp1251', 'x-cp1251' | | | 'windows-1252' | 'ansi_x3. 4-1968', 'ascii', 'cp1252', 'cp819', 'csisolatin1', 'ibm819', 'iso-8859-1', 'iso-ir-100', 'iso8859-1', 'iso88591', 'iso_8859-1', 'iso_8859-1', 'iso_8859-1: 1987', 'l1', 'latin1', 'us-ascii', 'x-cp1252' | | 'windows-1253' | 'cp1253', 'x-cp1253'.

| | 'windows-1254' | 'cp1254', 'csisolatin5', 'iso-8859-9', 'iso-ir-148', 'iso8859-9', 'iso88599', 'iso_8859-9', 'iso_8859-9:1989', 'l5', 'latin5', 'x-cp1254' | | 'windows-1255' | 'cp1255', 'x-cp1255' | | | 'windows-1256' | 'cp1256', 'x-cp1256' | | | 'windows-1257' | 'cp1257', 'x-cp1257' | | | 'windows-1258' | 'cp1258', 'x-cp1258' | | | x-mac-cyrillic'` |x-mac-ukrainian'| ``x-mac-ukrainian' | | 'gbk' | 'chinese', 'csgb2312', 'csiso58gb231280', 'gb2312', 'gb_2312', 'gb_2312-80', 'iso-ir-58', 'x-gbk' | | | 'gb18030'| | | | | |'big5|'big5-hkscs, `'cn-big5, 'csbig5``,'x-x-big5`| | |'euc-jp'|'cseucpkdfmtjapanese','x-euc-jp'| | |'iso-2022-jp'|'csiso2022jp'| |'shift_jis'|'csshiftjis','ms932','ms_kanji','shift-jis','sjis','windows-31j','x-sjis'`.

| 'euc-kr'|'cseuckr','csksc56011987','iso-ir-149','korean','ks_c_5601-1987','ks_c_5601-1989','ksc5601','ksc_5601','windows-949'` |

Кодировки, поддерживаемые при сборке Node.js с опцией small-icu.

Кодировка Псевдонимы
'utf-8' 'unicode-1-1-utf-8', 'utf8'
'utf-16le' | |'utf-16'
'utf-16be'

Кодировки, поддерживаемые при отключенном ICU

Кодировка Псевдонимы
'utf-8' 'unicode-1-1-utf-8', 'utf8'
'utf-16le' | |'utf-16' .

Кодировка 'iso-8859-16', указанная в WHATWG Encoding Standard, не поддерживается.

new TextDecoder([encoding[, options]]).

  • encoding <string> Определяет кодировку, которую поддерживает данный экземпляр ТекстДекодера. По умолчанию: 'utf-8'.
  • options <Object>
    • fatal <boolean> true, если сбои декодирования являются фатальными. Эта опция не поддерживается, если ICU отключен (см. Интернационализация). По умолчанию: false.
    • ignoreBOM <boolean> Когда true, TextDecoder будет включать метку порядка байтов в результат декодирования. При false метка порядка байтов будет удалена из результата. Эта опция используется, только если encoding - 'utf-8', 'utf-16be' или 'utf-16le'. По умолчанию: false.

Создает новый экземпляр TextDecoder. В encoding может быть указана одна из поддерживаемых кодировок или псевдоним.

Класс TextDecoder также доступен в глобальном объекте.

textDecoder.decode([input[, options]]).

  • вход {ArrayBuffer|DataView|TypedArray} Экземпляр ArrayBuffer, DataView или TypedArray, содержащий закодированные данные.
  • options <Object>
    • stream <boolean> true, если ожидаются дополнительные порции данных. По умолчанию: false.
  • Возвращает: <string>

Декодирует input и возвращает строку. Если options.stream имеет значение true, все неполные последовательности байтов, встречающиеся в конце ввода, буферизируются внутри и выдаются после следующего вызова textDecoder.decode().

Если textDecoder.fatal имеет значение true, то возникающие ошибки декодирования приведут к выбросу TypeError.

textDecoder.encoding

Кодировка, поддерживаемая экземпляром TextDecoder.

textDecoder.fatal

Значение будет true, если в результате ошибок декодирования будет выброшена TypeError.

textDecoder.ignoreBOM

Значение будет true, если результат декодирования будет включать метку порядка байтов.

Класс: util.TextEncoder.

Реализация API TextEncoder WHATWG Encoding Standard. Все экземпляры TextEncoder поддерживают только кодировку UTF-8.

1
2
const encoder = new TextEncoder();
const uint8array = encoder.encode('this is some data');

Класс TextEncoder также доступен на глобальном объекте.

textEncoder.encode([input])

  • ввод <string> Текст для кодирования. По умолчанию: пустая строка.
  • Возвращает: <Uint8Array>

UTF-8 кодирует строку input и возвращает Uint8Array, содержащий закодированные байты.

textEncoder.encodeInto(src, dest).

  • src[`](https://developer.mozilla.org/docs/Web/JavaScript/Data_structures#String_type) Текст для кодирования.
  • dest <Uint8Array> Массив для хранения результата кодирования.
  • Возвращает: <Object>
    • read <number> Прочитанные единицы кода Unicode src.
    • written <number> Записанные байты в формате UTF-8 из dest.

UTF-8 кодирует строку rc в Uint8Array dest и возвращает объект, содержащий считанные единицы кода Unicode и записанные байты UTF-8.

1
2
3
4
const encoder = new TextEncoder();
const src = 'this is some data';
const dest = new Uint8Array(10);
const { read, written } = encoder.encodeInto(src, dest);

textEncoder.encoding

Кодировка, поддерживаемая экземпляром TextEncoder. Всегда устанавливается на 'utf-8'.

util.toUSVString(string).

Возвращает строку после замены любых суррогатных кодовых точек (или, эквивалентно, любых непарных суррогатных кодовых единиц) на "символ замены" Юникода U+FFFD.

util.transferableAbortController().

Стабильность: 1 – Экспериментальная

Экспериментальный

Создает и возвращает экземпляр {AbortController}, чей <AbortSignal> помечен как передаваемый и может быть использован с structuredClone() или postMessage().

util.transferableAbortSignal(signal).

Стабильность: 1 – Экспериментальная

Экспериментальная

Маркирует данный <AbortSignal> как передаваемый, чтобы его можно было использовать с structuredClone() и postMessage().

1
2
3
4
5
const signal = transferableAbortSignal(
    AbortSignal.timeout(100)
);
const channel = new MessageChannel();
channel.port2.postMessage(signal, [signal]);

util.aborted(signal, resource)

Стабильность: 1 – Экспериментальная

Экспериментальная

  • signal <AbortSignal>
  • ресурс <Object> Любая ненулевая сущность, ссылка на которую удерживается слабо.
  • Возвращает: <Promise>

Слушает событие прерывания на предоставленном signal и возвращает обещание, которое будет выполнено, когда signal будет прерван. Если переданный ресурс будет собран до прерывания signal, возвращаемое обещание будет оставаться невыполненным неопределенное время.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
const { aborted } = require('node:util');

const dependent = obtainSomethingAbortable();

aborted(dependent.signal, dependent).then(() => {
    // Do something when dependent is aborted.
});

dependent.on('event', () => {
    dependent.abort();
});
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
import { aborted } from 'node:util';

const dependent = obtainSomethingAbortable();

aborted(dependent.signal, dependent).then(() => {
    // Do something when dependent is aborted.
});

dependent.on('event', () => {
    dependent.abort();
});

util.types

util.types обеспечивает проверку типов для различных видов встроенных объектов. В отличие от instanceof или Object.prototype.toString.call(value), эти проверки не проверяют свойства объекта, доступные из JavaScript (например, его прототип), и обычно имеют накладные расходы на обращение к C++.

Результат, как правило, не дает никаких гарантий относительно того, какие свойства или поведение значение раскрывает в JavaScript. Они в первую очередь полезны для разработчиков аддонов, которые предпочитают делать проверку типов в JavaScript.

API доступен через require('node:util').types или require('node:util/types').

util.types.isAnyArrayBuffer(value)

Возвращает true, если значение является встроенным экземпляром ArrayBuffer или SharedArrayBuffer.

См. также util.types.isArrayBuffer() и util.types.isSharedArrayBuffer().

1
2
util.types.isAnyArrayBuffer(new ArrayBuffer()); // Returns true
util.types.isAnyArrayBuffer(new SharedArrayBuffer()); // Returns true

util.types.isArrayBufferView(value)

Возвращает true, если значение является экземпляром одного из представлений ArrayBuffer, таких как типизированные объекты массивов или DataView. Эквивалентно ArrayBuffer.isView().

1
2
3
4
5
6
util.types.isArrayBufferView(new Int8Array()); // true
util.types.isArrayBufferView(Buffer.from('hello world')); // true
util.types.isArrayBufferView(
    new DataView(new ArrayBuffer(16))
); // true
util.types.isArrayBufferView(new ArrayBuffer()); // false

util.types.isArgumentsObject(value)

Возвращает true, если значение является объектом arguments.

1
2
3
function foo() {
    util.types.isArgumentsObject(arguments); // Returns true
}

util.types.isArrayBuffer(value)

Возвращает true, если значение является экземпляром встроенного ArrayBuffer. Это не включает экземпляры SharedArrayBuffer. Обычно желательно проверять оба варианта; см. об этом в util.types.isAnyArrayBuffer().

1
2
util.types.isArrayBuffer(new ArrayBuffer()); // Returns true
util.types.isArrayBuffer(new SharedArrayBuffer()); // Returns false

util.types.isAsyncFunction(value)

Возвращает true, если значение является асинхронной функцией. Это только сообщает о том, что видит движок JavaScript; в частности, возвращаемое значение может не совпадать с исходным кодом, если использовался инструмент транспиляции.

1
2
util.types.isAsyncFunction(function foo() {}); // Returns false
util.types.isAsyncFunction(async function foo() {}); // Returns true

util.types.isBigInt64Array(value)

Возвращает true, если значение является экземпляром BigInt64Array.

1
2
util.types.isBigInt64Array(new BigInt64Array()); // Returns true
util.types.isBigInt64Array(new BigUint64Array()); // Returns false

util.types.isBigUint64Array(value)

Возвращает true, если значение является экземпляром BigUint64Array.

1
2
util.types.isBigUint64Array(new BigInt64Array()); // Returns false
util.types.isBigUint64Array(new BigUint64Array()); // Returns true

util.types.isBooleanObject(value)

Возвращает true, если значение является булевым объектом, например, созданным с помощью new Boolean().

1
2
3
4
5
6
util.types.isBooleanObject(false); // Returns false
util.types.isBooleanObject(true); // Returns false
util.types.isBooleanObject(new Boolean(false)); // Returns true
util.types.isBooleanObject(new Boolean(true)); // Returns true
util.types.isBooleanObject(Boolean(false)); // Returns false
util.types.isBooleanObject(Boolean(true)); // Returns false

util.types.isBoxedPrimitive(value)

Возвращает true, если значение является любым объектом boxed primitive, например, созданным с помощью new Boolean(), new String() или Object(Symbol()).

Например:

1
2
3
4
5
util.types.isBoxedPrimitive(false); // Returns false
util.types.isBoxedPrimitive(new Boolean(false)); // Returns true
util.types.isBoxedPrimitive(Symbol('foo')); // Returns false
util.types.isBoxedPrimitive(Object(Symbol('foo'))); // Returns true
util.types.isBoxedPrimitive(Object(BigInt(5))); // Returns true

util.types.isCryptoKey(value)

Возвращает true, если значение является {CryptoKey}, false в противном случае.

util.types.isDataView(value)

Возвращает true, если значение является встроенным экземпляром DataView.

1
2
3
const ab = new ArrayBuffer(20);
util.types.isDataView(new DataView(ab)); // Returns true
util.types.isDataView(new Float64Array()); // Returns false

См. также ArrayBuffer.isView().

util.types.isDate(value)

Возвращает true, если значение является встроенным экземпляром Date.

1
util.types.isDate(new Date()); // Returns true

util.types.isExternal(value)

Возвращает true, если значение является родным External значением.

Родное External значение - это специальный тип объекта, который содержит необработанный указатель C++ (void*) для доступа из родного кода и не имеет других свойств. Такие объекты создаются либо внутренними компонентами Node.js, либо нативными аддонами. В JavaScript это frozen объекты с прототипом null.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
#include <js_native_api.h>
#include <stdlib.h>
napi_value result;
static napi_value MyNapi(napi_env env, napi_callback_info info) {
  int* raw = (int*) malloc(1024);
  napi_status status = napi_create_external(env, (void*) raw, NULL, NULL, &result);
  if (status != napi_ok) {
    napi_throw_error(env, NULL, "napi_create_external failed");
    return NULL;
  }
  return result;
}
...
DECLARE_NAPI_PROPERTY("myNapi", MyNapi)
...
1
2
3
4
5
const native = require('napi_addon.node');
const data = native.myNapi();
util.types.isExternal(data); // returns true
util.types.isExternal(0); // returns false
util.types.isExternal(new String('foo')); // returns false

Более подробную информацию о napi_create_external смотрите в napi_create_external().

util.types.isFloat32Array(value)

Возвращает true, если значение является встроенным экземпляром Float32Array.

1
2
3
util.types.isFloat32Array(new ArrayBuffer()); // Returns false
util.types.isFloat32Array(new Float32Array()); // Returns true
util.types.isFloat32Array(new Float64Array()); // Returns false

util.types.isFloat64Array(value)

Возвращает true, если значение является встроенным экземпляром Float64Array.

1
2
3
util.types.isFloat64Array(new ArrayBuffer()); // Returns false
util.types.isFloat64Array(new Uint8Array()); // Returns false
util.types.isFloat64Array(new Float64Array()); // Returns true

util.types.isGeneratorFunction(value)

Возвращает true, если значение является генераторной функцией. Это только сообщает о том, что видит движок JavaScript; в частности, возвращаемое значение может не совпадать с исходным кодом, если использовался инструмент транспиляции.

1
2
util.types.isGeneratorFunction(function foo() {}); // Returns false
util.types.isGeneratorFunction(function* foo() {}); // Returns true

util.types.isGeneratorObject(value)

Возвращает true, если значение является объектом генератора, возвращенным встроенной функцией генератора. Это только сообщает о том, что видит движок JavaScript; в частности, возвращаемое значение может не совпадать с исходным кодом, если использовался инструмент транспиляции.

1
2
3
function* foo() {}
const generator = foo();
util.types.isGeneratorObject(generator); // Returns true

util.types.isInt8Array(value)

Возвращает true, если значение является экземпляром встроенного Int8Array.

1
2
3
util.types.isInt8Array(new ArrayBuffer()); // Returns false
util.types.isInt8Array(new Int8Array()); // Returns true
util.types.isInt8Array(new Float64Array()); // Returns false

util.types.isInt16Array(value)

Возвращает true, если значение является экземпляром встроенного Int16Array.

1
2
3
util.types.isInt16Array(new ArrayBuffer()); // Returns false
util.types.isInt16Array(new Int16Array()); // Returns true
util.types.isInt16Array(new Float64Array()); // Returns false

util.types.isInt32Array(value)

Возвращает true, если значение является экземпляром встроенного Int32Array.

1
2
3
util.types.isInt32Array(new ArrayBuffer()); // Returns false
util.types.isInt32Array(new Int32Array()); // Returns true
util.types.isInt32Array(new Float64Array()); // Returns false

util.types.isKeyObject(value)

Возвращает true, если value является {KeyObject}, false в противном случае.

util.types.isMap(value)

Возвращает true, если значение является экземпляром встроенной Map.

1
util.types.isMap(new Map()); // Returns true

util.types.isMapIterator(value)

Возвращает true, если значение является итератором, возвращаемым для встроенного экземпляра Map.

1
2
3
4
5
const map = new Map();
util.types.isMapIterator(map.keys()); // Returns true
util.types.isMapIterator(map.values()); // Returns true
util.types.isMapIterator(map.entries()); // Returns true
util.types.isMapIterator(map[Symbol.iterator]()); // Returns true

util.types.isModuleNamespaceObject(value)

Возвращает true, если значение является экземпляром Module Namespace Object.

1
2
3
import * as ns from './a.js';

util.types.isModuleNamespaceObject(ns); // Returns true

util.types.isNativeError(value)

Возвращает true, если значение было возвращено конструктором встроенного типа Error.

1
2
3
console.log(util.types.isNativeError(new Error())); // true
console.log(util.types.isNativeError(new TypeError())); // true
console.log(util.types.isNativeError(new RangeError())); // true

Подклассы собственных типов ошибок также являются собственными ошибками:

1
2
class MyError extends Error {}
console.log(util.types.isNativeError(new MyError())); // true

Значение, являющееся stanceof класса нативной ошибки, не эквивалентно тому, что isNativeError() возвращает true для этого значения. isNativeError() возвращает true для ошибок, которые приходят из другой сферы, в то время как instanceof Error возвращает false для этих ошибок:

1
2
3
4
5
const vm = require('node:vm');
const context = vm.createContext({});
const myError = vm.runInContext('new Error', context);
console.log(util.types.isNativeError(myError)); // true
console.log(myError instanceof Error); // false

И наоборот, isNativeError() возвращает false для всех объектов, которые не были возвращены конструктором родной ошибки. Это включает значения, которые являются instanceof родных ошибок:

1
2
3
const myError = { __proto__: Error.prototype };
console.log(util.types.isNativeError(myError)); // false
console.log(myError instanceof Error); // true

util.types.isNumberObject(value)

Возвращает true, если значение является числовым объектом, например, созданным с помощью new Number().

1
2
util.types.isNumberObject(0); // Returns false
util.types.isNumberObject(new Number(0)); // Returns true

util.types.isPromise(value)

Возвращает true, если значение является встроенным Promise.

1
util.types.isPromise(Promise.resolve(42)); // Returns true

util.types.isProxy(value)

Возвращает true, если значение является экземпляром Proxy.

1
2
3
4
const target = {};
const proxy = new Proxy(target, {});
util.types.isProxy(target); // Returns false
util.types.isProxy(proxy); // Returns true

util.types.isRegExp(value)

Возвращает true, если значение является объектом регулярного выражения.

1
2
util.types.isRegExp(/abc/); // Returns true
util.types.isRegExp(new RegExp('abc')); // Returns true

util.types.isSet(value)

Возвращает true, если значение является экземпляром встроенного Set.

1
util.types.isSet(new Set()); // Returns true

util.types.isSetIterator(value)

Возвращает true, если значение является итератором, возвращаемым для встроенного экземпляра Set.

1
2
3
4
5
const set = new Set();
util.types.isSetIterator(set.keys()); // Returns true
util.types.isSetIterator(set.values()); // Returns true
util.types.isSetIterator(set.entries()); // Returns true
util.types.isSetIterator(set[Symbol.iterator]()); // Returns true

util.types.isSharedArrayBuffer(value)

Возвращает true, если значение является экземпляром встроенного SharedArrayBuffer. Это не включает экземпляры ArrayBuffer. Обычно желательно проверять оба варианта; см. об этом в util.types.isAnyArrayBuffer().

1
2
util.types.isSharedArrayBuffer(new ArrayBuffer()); // Returns false
util.types.isSharedArrayBuffer(new SharedArrayBuffer()); // Returns true

util.types.isStringObject(value)

Возвращает true, если значение является строковым объектом, например, созданным с помощью new String().

1
2
util.types.isStringObject('foo'); // Returns false
util.types.isStringObject(new String('foo')); // Returns true

util.types.isSymbolObject(value)

Возвращает true, если значение является объектом символа, созданным вызовом Object() на примитиве Symbol.

1
2
3
const symbol = Symbol('foo');
util.types.isSymbolObject(symbol); // Returns false
util.types.isSymbolObject(Object(symbol)); // Returns true

util.types.isTypedArray(value)

Возвращает true, если значение является экземпляром встроенного TypedArray.

1
2
3
util.types.isTypedArray(new ArrayBuffer()); // Returns false
util.types.isTypedArray(new Uint8Array()); // Returns true
util.types.isTypedArray(new Float64Array()); // Returns true

См. также ArrayBuffer.isView().

util.types.isUint8Array(value)

Возвращает true, если значение является экземпляром встроенного Uint8Array.

1
2
3
util.types.isUint8Array(new ArrayBuffer()); // Returns false
util.types.isUint8Array(new Uint8Array()); // Returns true
util.types.isUint8Array(new Float64Array()); // Returns false

util.types.isUint8ClampedArray(value)

Возвращает true, если значение является встроенным экземпляром Uint8ClampedArray.

1
2
3
util.types.isUint8ClampedArray(new ArrayBuffer()); // Returns false
util.types.isUint8ClampedArray(new Uint8ClampedArray()); // Returns true
util.types.isUint8ClampedArray(new Float64Array()); // Returns false

util.types.isUint16Array(value)

Возвращает true, если значение является экземпляром встроенного Uint16Array.

1
2
3
util.types.isUint16Array(new ArrayBuffer()); // Returns false
util.types.isUint16Array(new Uint16Array()); // Returns true
util.types.isUint16Array(new Float64Array()); // Returns false

util.types.isUint32Array(value)

Возвращает true, если значение является экземпляром встроенного Uint32Array.

1
2
3
util.types.isUint32Array(new ArrayBuffer()); // Returns false
util.types.isUint32Array(new Uint32Array()); // Returns true
util.types.isUint32Array(new Float64Array()); // Returns false

util.types.isWeakMap(value)

Возвращает true, если значение является экземпляром встроенной WeakMap.

1
util.types.isWeakMap(new WeakMap()); // Returns true

util.types.isWeakSet(value)

Возвращает true, если значение является экземпляром встроенного WeakSet.

1
util.types.isWeakSet(new WeakSet()); // Returns true

util.types.isWebAssemblyCompiledModule(value).

Стабильность: 0 – устарело или набрало много негативных отзывов

Используйте value instanceof WebAssembly.Module вместо этого.

Возвращает true, если значение является экземпляром встроенного WebAssembly.Module.

1
2
const module = new WebAssembly.Module(wasmBuffer);
util.types.isWebAssemblyCompiledModule(module); // Returns true

Устаревшие API

Следующие API являются устаревшими и больше не должны использоваться. Существующие приложения и модули должны быть обновлены для поиска альтернативных подходов.

util._extend(target, source).

Стабильность: 0 – устарело или набрало много негативных отзывов

Вместо этого используйте Object.assign().

Метод util._extend() никогда не предназначался для использования вне внутренних модулей Node.js. Однако сообщество все равно нашло и использовало его.

Он устарел и не должен использоваться в новом коде. JavaScript поставляется с очень похожей встроенной функциональностью через Object.assign().

util.isArray(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Вместо этого используйте Array.isArray().

Псевдоним для Array.isArray().

Возвращает true, если данный объект является массивом. В противном случае возвращается false.

1
2
3
4
5
6
7
8
const util = require('node:util');

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

util.isBoolean(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Вместо этого используйте typeof value === 'boolean'.

Возвращает true, если данный объект является булевым. В противном случае возвращается false.

1
2
3
4
5
6
7
8
const util = require('node:util');

util.isBoolean(1);
// Returns: false
util.isBoolean(0);
// Returns: false
util.isBoolean(false);
// Returns: true

util.isBuffer(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Используйте Buffer.isBuffer() вместо этого.

Возвращает true, если данный объект является буфером. В противном случае возвращается false.

1
2
3
4
5
6
7
8
const util = require('node:util');

util.isBuffer({ length: 0 });
// Returns: false
util.isBuffer([]);
// Returns: false
util.isBuffer(Buffer.from('hello world'));
// Returns: true

util.isDate(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Используйте util.types.isDate() вместо этого.

Возвращает true, если данный объект является датой. В противном случае возвращает false.

1
2
3
4
5
6
7
8
const util = require('node:util');

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

util.isError(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Используйте util.types.isNativeError() вместо этого.

Возвращает true, если данный объект является ошибкой. В противном случае возвращается false.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
const util = require('node:util');

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

Этот метод полагается на поведение Object.prototype.toString(). Возможно получение неправильного результата, когда аргумент object манипулирует @@toStringTag.

1
2
3
4
5
6
7
8
const util = require('node:util');
const obj = { name: 'Error', message: 'an error occurred' };

util.isError(obj);
// Returns: false
obj[Symbol.toStringTag] = 'Error';
util.isError(obj);
// Returns: true

util.isFunction(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Вместо этого используйте typeof value === 'function'.

Возвращает true, если данный объект является функцией. В противном случае возвращает false.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
const util = require('node:util');

function Foo() {}
const Bar = () => {};

util.isFunction({});
// Returns: false
util.isFunction(Foo);
// Returns: true
util.isFunction(Bar);
// Returns: true

util.isNull(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Вместо этого используйте value === null.

Возвращает true, если данный объект строго null. В противном случае возвращается false.

1
2
3
4
5
6
7
8
const util = require('node:util');

util.isNull(0);
// Returns: false
util.isNull(undefined);
// Returns: false
util.isNull(null);
// Returns: true

util.isNullOrUndefined(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Вместо этого используйте value === undefined || value === null.

Возвращает true, если данный объект является null или undefined. В противном случае возвращается false.

1
2
3
4
5
6
7
8
const util = require('node:util');

util.isNullOrUndefined(0);
// Returns: false
util.isNullOrUndefined(undefined);
// Returns: true
util.isNullOrUndefined(null);
// Returns: true

util.isNumber(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Вместо этого используйте typeof value === 'number'.

Возвращает true, если данный объект является число. В противном случае возвращает false.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
const util = require('node:util');

util.isNumber(false);
// Returns: false
util.isNumber(Infinity);
// Returns: true
util.isNumber(0);
// Returns: true
util.isNumber(NaN);
// Returns: true

util.isObject(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Используйте value !== null && typeof value === 'object' вместо этого.

Возвращает true, если данный object является строго Object и не Function (даже если функции являются объектами в JavaScript). В противном случае возвращается false.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
const util = require('node:util');

util.isObject(5);
// Returns: false
util.isObject(null);
// Returns: false
util.isObject({});
// Returns: true
util.isObject(() => {});
// Returns: false

util.isPrimitive(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Используйте (typeof value !== 'object' && typeof value !== 'function') || value === null вместо этого.

Возвращает true, если данный object является примитивным типом. В противном случае возвращает false.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
const util = require('node:util');

util.isPrimitive(5);
// Returns: true
util.isPrimitive('foo');
// Returns: true
util.isPrimitive(false);
// Returns: true
util.isPrimitive(null);
// Returns: true
util.isPrimitive(undefined);
// Returns: true
util.isPrimitive({});
// Returns: false
util.isPrimitive(() => {});
// Returns: false
util.isPrimitive(/^$/);
// Returns: false
util.isPrimitive(new Date());
// Returns: false

util.isRegExp(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Утратил актуальность

Возвращает true, если данный объект является RegExp. В противном случае возвращается false.

1
2
3
4
5
6
7
8
const util = require('node:util');

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

util.isString(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Вместо этого используйте typeof value === 'string'.

Возвращает true, если данный объект является строкой. В противном случае возвращает false.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
const util = require('node:util');

util.isString('');
// Returns: true
util.isString('foo');
// Returns: true
util.isString(String('foo'));
// Returns: true
util.isString(5);
// Returns: false

util.isSymbol(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Вместо этого используйте typeof value === 'symbol'.

Возвращает true, если данный объект является символом. В противном случае возвращается false.

1
2
3
4
5
6
7
8
const util = require('node:util');

util.isSymbol(5);
// Returns: false
util.isSymbol('foo');
// Returns: false
util.isSymbol(Symbol('foo'));
// Returns: true

util.isUndefined(object).

Стабильность: 0 – устарело или набрало много негативных отзывов

Вместо этого используйте value === undefined.

Возвращает true, если данный объект является неопределенным. В противном случае возвращает false.

1
2
3
4
5
6
7
8
9
const util = require('node:util');

const foo = undefined;
util.isUndefined(5);
// Returns: false
util.isUndefined(foo);
// Returns: true
util.isUndefined(null);
// Returns: false

util.log(string).

Стабильность: 0 – устарело или набрало много негативных отзывов

Вместо этого используйте сторонний модуль.

Метод util.log() печатает заданную строку в stdout с включенной меткой времени.

1
2
3
const util = require('node:util');

util.log('Timestamped message.');