Аватар для Eur93
47 / 47 / 24
Регистрация: 16.09.2013
Сообщений: 349

Вывод данных через ajax с типом данных JSON

19.01.2014, 01:44. Показов 2625. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Если я из обработчика пишу это, выведет, как и ежу понятно, 1 кнопку.
PHP
1
2
3
4
...
$res = mysqli_query($db, 'SELECT `podmenu_name` FROM оттуда-то WHERE то-то');
$row = mysqli_fetch_array($res);
echo json_encode('<button id="butmenu2">'.$row['podmenu_name'].'</button>');
Но вообще в массиве
PHP
1
$row = mysqli_fetch_array($res);
несколько значений, допустим, кот, собака и лошадь. Как мне вывести три кнопки? Если такой способ не работает (возможно, где-то я ошибся)?

PHP
1
2
3
4
5
...
$res = mysqli_query($db, 'SELECT `podmenu_name` FROM оттуда-то WHERE то-то');
while ($row = mysqli_fetch_array($res)) {
     echo json_encode('<button id="butmenu2">'.$row['podmenu_name'].'</button>');
}
Прошу помощи.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
19.01.2014, 01:44
Ответы с готовыми решениями:

Получение данных из файла JSON через Ajax
Всем доброго времени суток. Столкнулся с проблемой получения JSON-данных с сервера. На сервере лежит файл .json, в котором находятся...

Передача json данных методом POST через AJAX
нужно передать данные на сервер методом post передача на сервер req.open(&quot;POST&quot;, &quot;/controller/ajax.php&quot;) ...

передача json данных с внешнего сервера через клиент в базу данных
Доброго времени суток. Времени до завтра мало, а который день бьюсь уже, новичок в этом деле. Имеется внешний сервер с json данными,...

3
 Аватар для Lazy_Den
3325 / 2845 / 1423
Регистрация: 15.01.2014
Сообщений: 6,170
19.01.2014, 11:18
Красивенько "упакуйте" данные в строку или массив (смотря, что вам надо) и отправляйте ответом уже их:
PHP
1
2
3
4
5
6
7
8
9
$str = '';
//$arr = array(); // если массив
while ($row = mysqli_fetch_array($res)) {
     $str .= '<button id="butmenu2">'.$row['podmenu_name'].'</button>';
     // $arr[] = '<button id="butmenu2">'.$row['podmenu_name'].'</button>'; // для массива
}
echo json_encode($str);
// echo json_encode($arr); // соответственно
exit;
1
 Аватар для Eur93
47 / 47 / 24
Регистрация: 16.09.2013
Сообщений: 349
19.01.2014, 14:02  [ТС]
Lazy_Den, Спасибо, еще один вопрос, чтобы потом снова далеко не бегать.

когда пришла переменная на страницу index.php и распоковала кнопочки,
Цитата Сообщение от Lazy_Den Посмотреть сообщение
cho json_encode($str);
могу ли я над этими кнопками совершать действия?

А то пишу самый обычный скрипт, а не канает... Как мне поступить? Мне необходимо, чтобы эти кнопки совершали другое действие.

Вот пример, который не канает. (В кнопке из прошлого сообщения id поменял на class)
HTML5
1
<input id="trololo" type="text" value=""></input>
JavaScript
1
2
3
$(document).ready(function() {
    $('.butmenu2').click(function(){ 
        $("#trololo").val(10); }); });
0
 Аватар для Lazy_Den
3325 / 2845 / 1423
Регистрация: 15.01.2014
Сообщений: 6,170
19.01.2014, 20:29
Для динамически созданных элементов, надо использовать метод .on() и желательно с делегированной обработкой событий. Про такой метод, как .live(), если вы его используете или вообще слышали - забыть. Про делегированную обработку, попробую объяснить простым языком:
Вешаем событие на динамический элемент, отталкиваясь от его статичного родителя (может быть даже body). Возьмем, к примеру, элемент #parent_block и подгрузим в него средствами ajax другой - #dynamic_childe. Теперь, чтоб событие клика работало на #dynamic_childe, мы запишем это так:
JavaScript
1
2
3
$('#parent_block').on('click', '#dynamic_childe', function(){
    // this - будет именно объект #dynamic_childe, а не #parent_block
});
В вашем случае, надо знать - динамический элемент .butmenu2 или нет. если статический, то вполне достаточно использовать on() без делигированной обработки, в противном случае - искать ближайший статический элемент:
JavaScript
1
2
3
4
5
6
7
8
// или 
$('.butmenu2').on('click', function(){ 
    $("#trololo").val(10); 
}); 
// или 
$('body').on('click', '.butmenu2', function(){
    $("#trololo").val(10); 
});
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.01.2014, 20:29
Помогаю со студенческими работами здесь

Нужно перевести переменную с типом данных string в переменную с типом данных REAL
Итак, нужно перевести переменную с типом данных string в переменную с типом данных REAL. Переменную вводит пользователь, поэтому нужно...

MVC3 JQuery Ajax передача JSON данных от клиента серверу
Код на клиенте $.ajax({url:'@Url.Action( &quot;Index&quot; )', type:'POST', ...

Ajax запрос отправка данных(json) на сервер и data=type init!?
Как в этот ajax запрос вставить данные, у меня тут указано data: &quot;type = init&quot;, но мне нужно еще 1-у переменную передать, допустим x, куда...

Запрос к базе данных через форму и вывод данных на страничке
Всем привет. Очень нужна ваша помощь, вы моя последняя надежда. У меня стоит одна форма и ввожу имя человека который проходит тест, потом...

Голосовой ввод данных и вывод данных через динамики
На Android есть приложение &quot;Pasal N-IDE&quot; Там есть модули для ввода и вывода данных через микрофон и динамики&quot;aRecognition&quot; и...


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

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

Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru