7 / 7 / 5
Регистрация: 28.07.2014
Сообщений: 104

Правильное формирование и разбор JSON

07.03.2016, 01:58. Показов 3482. Ответов 20
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Ситуация такова: есть таблица в mySQL, со следующими полями id, description, longitude, latitude. Таблица заполнена, description - название здания, longitude, latitude - координаты.
В php я создаю и заполняю массив который выдергивает эти координаты, если это здание упоминается в другом массиве. Создаю и заполняю вот так.
PHP
1
2
3
4
5
6
7
8
9
10
11
foreach ($records as $row)
        {
            $coordinates = array();             
            $coordinate = $mysqli->query("SELECT longitude, latitude FROM housing WHERE description='".$row['id_housing']."'");
                while ($kd = $coordinate->fetch_assoc())
                {
                    $coordinates[] = $kd;
                }
/*Перевожу массив в JSON*/
                $a = json_encode($coordinates);
        }
Теперь мне необходимо разобрать JSON в JS. Но как я ни гуглил не пойму как это сделать. Да и сам JSON у меня странно выглядит - 2 разных здания - 2 пары квадратных скобок:
PHP
1
2
3
                $a = json_encode($coordinates);
                echo $a;
/*JSON - [{"longitude":"55.830457","latitude":"37.554969"}][{"longitude":"55.832995","latitude":"37.549956"}]*/
2 пары квадратных скобок это нормально или всё должно быть в одних квадратных скобках?
Что я хочу от скрипта JS. Цикл, который перебирает массив JSON и присваивает переменной X - значение longitude, а Y - значение latitude.
JavaScript
1
2
3
4
var coordinates = JSON.parse(<?php echo $a;?>, function(key, value)
            {
/*мне кажется у меня в coordinates только половина [{"longitude":"55.830457","latitude":"37.554969"}] */
            });
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.03.2016, 01:58
Ответы с готовыми решениями:

Разбор многомерного массива (Json, мультиполигон)
Имеется массив вида: , , , , ], , , ] ] С помощью функции function parseArray(arr) { var newArr = ;...

Разбор JSON и вывод таблицы с одной строкой + AJAX
вот код &lt;html&gt; &lt;head&gt; &lt;meta charset=&quot;UTF-8&quot;&gt; &lt;title&gt;JDBC Examples&lt;/title&gt; &lt;link rel=&quot;stylesheet&quot;...

Разбор JSON, используя Newtonsoft.Json
Добрый день! Подскажите пожалуйста, как десериализовать JSON-ответ следующего вида {&quot;result&quot;: ...

20
7 / 7 / 5
Регистрация: 28.07.2014
Сообщений: 104
07.03.2016, 18:40  [ТС]
Студворк — интернет-сервис помощи студентам
temkasky, огромное спасибо! Очень помогли. Сразу не заработало, но я поправил.
JavaScript
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
        <script type="text/javascript">
            var myMap, myRoute;
                ymaps.ready(init);
            function init ()
            {
                myMap = new ymaps.Map ("myMap",
                {
                    center: [55.830457, 37.554969], 
                    zoom: 15,
                    behaviors: ['default', 'scrollZoom']
                });
                myMap.controls.add('zoomControl');
                myMap.controls.add('typeSelector');
                var str = '<?php echo $a;?>';
                parseObject(str);               
            };
            function parseObject(obj)
                {
                    obj = JSON.parse(obj);
                    for(var i = 0; i < obj.length; i++){
                        x = obj[i][0].longitude;
                        y = obj[i][0].latitude;
                        var myPlacemark = new ymaps.Placemark([x, y]);
                        myMap.geoObjects.add(myPlacemark);
                        x=0; y=0;
                    }
                };
        </script>
Добавлено через 5 минут
JavaScript
1
parseObject('<?php echo $a;?>');
так тоже работает

Добавлено через 55 минут
temkasky, можно ещё вопросик?
Чтобы каши не было, я бы вынес скрипт с картой в отдельный файл js, но там ведь переменная php.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.03.2016, 18:40
Помогаю со студенческими работами здесь

Правильное формирование базы
Здравствуйте, нужна помощь с созданием одной таблицы, описывающей посты на форуме. Структура такая(примерно): ID_post - код поста ...

Правильное формирование XML файла
Добрый вечер друзья помогите правильно сформировать XML файл. Написал метод который формирует XML ublic void SaverAgenda(string...

Правильное формирование данных в таблице
Добрый час Форумчане! Помогите с формированием данных в таблице. Я занимаюсь линиями ВЛ и хочу автоматизировать подсчёт...

Вывод по тексту и правильное формирование сайта
Вывод по тексту. Вообще сделал начало вывод по id, все нормально, но как сделать вывод по test, проблема в том, что если там предложение,...

Qt разбор JSON
все не могу разобраться в json, с vk возвращает это: &quot;{&quot;response&quot;:180075}&quot; мне нужно чтобы в лист вернуло информацию. ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
21
Ответ Создать тему
Опции темы

Новые блоги и статьи
попытка написать игровой сервер на C++
pyirrlicht 29.04.2026
попытка написать игровой сервер на плюсах с открытым бесконечным миром. возможно получится прикрутить интерпретатор питон для кастомизации игровой логики. что есть на текущий момент:. . .
Контроль уникальности выбранного документа-основания при изменении реквизита
Maks 28.04.2026
Алгоритм из решения ниже разработан на примере нетипового документа "ЗаявкаНаРемонтСпецтехники", разработанного в КА2. Задача: уведомлять пользователя, если указанная заявка (документ-основание). . .
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru