|
1 / 1 / 0
Регистрация: 22.11.2018
Сообщений: 7
|
||||||||||||
JSON создание структуры данных и вывод на экран27.11.2018, 18:36. Показов 4771. Ответов 12
Всем доброго времени суток! Постигаю, так сказать, Javascript.
C сервера получаю JSON вида в массив:
В итоге, данные группируются только по дате. Вопрос - как группировать по остальным ключам? Я правильно понимаю, нужно преобразовать полученный JSON в массив с вложенными элементами, но как это сделать? Надеюсь, я все понятно объяснил, буду благодарен за помощь или указание верного направления
1
|
||||||||||||
| 27.11.2018, 18:36 | |
|
Ответы с готовыми решениями:
12
Не могу понять как делать вывод на экран структуры STUDENT на заполнение и вывод данных на экран
Создание, сортировка, вывод на экран файла записей (структуры) "Изделие" |
|
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
|
|
| 27.11.2018, 18:56 | |
|
SergeevAS, в официальной дате документа обычно компонент времени отсекается.
Получаем группировку по календарной дате и по id документа. Название документа обычно вторично по отношению к id, по названию не сортируют. А если нужен отдельный тип документа, то у типа должно быть своё поле id типа. Внутри документа можно например сортировать товары по наименованию productName.
1
|
|
|
1 / 1 / 0
Регистрация: 22.11.2018
Сообщений: 7
|
|
| 28.11.2018, 10:04 [ТС] | |
|
amr-now, в том-то и дело, что не знаю, как сгруппировать по двум элементам, т. е. id должен быть вложен в календарную дату
0
|
|
|
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
|
||||||||||||||||
| 28.11.2018, 21:44 | ||||||||||||||||
|
SergeevAS, у Вас JSON сформирован так что прицепиться в цикле почти не за что. К примеру две разных записи, имеют одинаковые docId или docName.
Если вид, что Вам нужен, не критичен, то - https://codepen.io/qwerty_wasd/pen/mQGOOR
1
|
||||||||||||||||
|
1 / 1 / 0
Регистрация: 22.11.2018
Сообщений: 7
|
|
| 29.11.2018, 10:22 [ТС] | |
|
Qwerty_Wasd, большое спасибо за ответ. На самом деле, json для примера я сильно упростил.
Суть в том, что по одному docId могут приходить разные значения docName, productName и price, поэтому необходимо реализовать и группировку по docId. В вашем примере только по дате, что я и сам сделал. Но Ваш подход интереснее)
0
|
|
|
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
|
|
| 29.11.2018, 10:33 | |
|
SergeevAS, у Вас очень интересная тема для исследования механизма обработки информации в JavaScript.
Маленький уточняющий вопрос. Объясните, пожалуйста, назначение поля docName. Чем оно отличается от docId? Это ремарка к документу? Или это название категории документов? И где вообще хранится человеко-видимый номер документа? id может быть невидимым идентификатором из базы данных.
0
|
|
|
1 / 1 / 0
Регистрация: 22.11.2018
Сообщений: 7
|
||
| 29.11.2018, 10:51 [ТС] | ||
|
amr-now, docName это название категории документов. docId и есть человеко-видимый)
0
|
||
|
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
|
|||
| 29.11.2018, 11:30 | |||
|
SergeevAS, то есть в каждой категории документов своя отдельная нумерация docId?
Обычно Приказ №1 не имеет сквозную нумерацию со счет-фактурой №1. Добавлено через 6 минут - календарная дата. - категория документов, - номер документа. Если просто внутри даты сортируем по номеру, тогда нумерация сквозная для всех категорий товарных документов? И по категории документов не сортируем? Добавлено через 9 минут Тогда по логике, нужно сначала сортировать по категории документа, а потом уже по номеру. Иначе мы увидим десять документов №123, затем их разбивку по категориям. А зачем нам нужно брать компактно десять документов с одинаковым номером?
0
|
|||
|
1 / 1 / 0
Регистрация: 22.11.2018
Сообщений: 7
|
||
| 29.11.2018, 11:45 [ТС] | ||
|
amr-now, порядок составления docId различается в зависимости от типа, поэтому двух документов разного типа с одинаковым docId быть не может.
Но вопрос темы именно в реализации вложенной сортировки, не могу понять механизм.
0
|
||
|
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
|
|
| 29.11.2018, 12:26 | |
|
SergeevAS, то есть сортировка непосредственно по наименованию категории вообще не нужна?
Правильная сортировка по категории документа уже зашита в номере документа?
0
|
|
|
1 / 1 / 0
Регистрация: 22.11.2018
Сообщений: 7
|
|
| 29.11.2018, 13:29 [ТС] | |
|
amr-now, получается, что так.
0
|
|
|
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
|
||||||
| 29.11.2018, 13:59 | ||||||
|
SergeevAS, на всякой случай пока оставил сортировку сначала по наименованию категории документа, потом по номеру документа. Если не надо, то легко и упростить.
Буду доделывать группировку, если ключ группировки - объект, а не примитив. Сейчас там дата превращена в ключе в число. Добавлено через 5 минут Кстати, в данном варианте прямое отражение реляционных таблиц в объекты JS. Можно сделать и второй вариант ультра-модной богатой доменной модели.
1
|
||||||
|
1 / 1 / 0
Регистрация: 22.11.2018
Сообщений: 7
|
||
| 29.11.2018, 15:26 [ТС] | ||
|
amr-now, не ожидал, что программа так разрастется, спасибо за решение и пояснения) Буду изучать.
0
|
||
| 29.11.2018, 15:26 | |
|
Помогаю со студенческими работами здесь
13
Конвертация в файл формата json древовидной структуры данных Как добиться определённой структуры данных при создании файла JSON? Вывод данных через ajax с типом данных JSON
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод
Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод.
Thinkpad X220 Tablet —. . .
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|