Обработка преобразовывает JSON в дерево значений. Работает на управляемых формах (8.3.11.2924).
Есть возможности:
- выбрать кодировку.
- считывать данные напрямую из файла.
- считывать данные по ссылке (GET запрос).
- сразу на форме вставлять текст в формате JSON и преобразовывать его.
Из полезного по коду (по моему скромному мнению), вдруг кому пригодится:
Ниже представлен код рекурсивной функции, по преобразованию полученного массива данных JSON штатными средствами ("Новый ЧтениеJSON"), в дерево значений.
&НаСервере
Функция СформироватьДерево(НашаСтруктура,ТекущееДерево)
Для каждого СтрокаСтруктуры из НашаСтруктура цикл
Если ТипЗнч(СтрокаСтруктуры)=Тип("КлючИЗначение") тогда
ПодчиненнаяСтрока=ТекущееДерево.Строки.Добавить();
ПодчиненнаяСтрока.Ключ=СтрокаСтруктуры.Ключ;
Если ТипЗнч(СтрокаСтруктуры.Значение)=Тип("Соответствие") или ТипЗнч(СтрокаСтруктуры.Значение)=Тип("Массив") тогда
СформироватьДерево(СтрокаСтруктуры.Значение,ПодчиненнаяСтрока)
Иначе
ПодчиненнаяСтрока.Значение=СтрокаСтруктуры.Значение;
КонецЕсли;
ИначеЕсли ТипЗнч(СтрокаСтруктуры)=Тип("Соответствие") или ТипЗнч(СтрокаСтруктуры)=Тип("Массив") тогда
ПодчиненнаяСтрока=ТекущееДерево.Строки.Добавить();
ПодчиненнаяСтрока.Ключ="";
ПодчиненнаяСтрока.Значение="[...]";
СформироватьДерево(СтрокаСтруктуры,ПодчиненнаяСтрока);
Иначе
ПодчиненнаяСтрока=ТекущееДерево.Строки.Добавить();
ПодчиненнаяСтрока.Значение=СтрокаСтруктуры;
КонецЕсли;
КонецЦикла;
КонецФункции
Где "НашаСтруктура" - структуры/массивы JSON. А "ТекущееДерево" - строка созданного дерева значений.
Соответственно перед вызовом данной рекурсии необходимо создать переменную с типо Дерево значений и передать первую строку, в моём примере, что бы она не была пустая, заполняю её текстовым значение "Структура".
Дерево= новый ДеревоЗначений;
Дерево.Колонки.Добавить("Ключ");
Дерево.Колонки.Добавить("Значение");
ВерхнийУровеньдерева=Дерево.Строки.Добавить();
ВерхнийУровеньдерева.Ключ="Структура JSON";
СформироватьДерево(НашиДанныеJSON,ВерхнийУровеньдерева);
Публикация первая, так что сильно не кричите.