Espruino:Справочник по API/Класс E/toJS(): различия между версиями

Материал из Онлайн справочника
Перейти к навигацииПерейти к поиску
Нет описания правки
Нет описания правки
Строка 7: Строка 7:
==Синтаксис==
==Синтаксис==


<syntaxhighlight lang="javascript" enclose="div">
<syntaxhighlight lang="javascript">
E.toJS(arg)
E.toJS(arg)
</syntaxhighlight>
</syntaxhighlight>

Версия от 18:28, 14 мая 2023

Перевод: Максим Кузьмин
Проверка/Оформление/Редактирование: Мякишев Е.А.


Функция E.toJS()[1]

Синтаксис

E.toJS(arg)

Параметры

  • arg – JS-переменная, которую надо преобразовать в строку

Возвращаемое значение

Строку.

Описание

Выполняет ту же базовую функцию, что и JSON.stringify(), но JSON.stringify() также добавляет несколько дополнительных символов, чтобы соответствовать стандарту JSON, тогда как для JS-переменных эти символы не требуются.

Кроме того, E.toJS() умеет преобразовывать в строки JS-функции, тогда как JSON.stringify() их игнорирует.

Например:

  • JSON.stringify({a:1,b:2}) == '{"a":1,"b":2}'
  • E.toJS({a:1,b:2}) == '{a:1,b:2}'

Примечание: Строки, созданные с помощью E.toJS(), невозможно корректно пропарсить при помощи JSON.parse(). Впрочем, эти строки являются корректными JS-переменными, так что здесь допустимо использование eval() (но тут есть ограничения по безопасности, если вы не доверяете источнику, из которого пришла строка). ПК-парсер JSON5 без проблем парсит строки, сгенерированные с помощью E.toJS().

См.также

Внешние ссылки