Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 25.07.2019
Сообщений: 25

Передача id элементов внутри загружаемой с обработчика таблицы

07.08.2019, 12:51. Показов 579. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет!

Есть JS:
//Здесь по клику передаётся id элемента в обработчик redact.php и данные появляются в скрытом div(который потом отображается как pop up с информацией из обработчика)
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
document.addEventListener("click", function (e) {
    var id = e.target.id;
    console.log(id);
   // передача значения этого id
    var xhr = new XMLHttpRequest();
    xhr.open('POST','redact.php',false);
    xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
    xhr.send(id);
    if (xhr.status != 200) {
              alert( xhr.status + ': ' + xhr.statusText ); 
      } else {
         document.getElementById('redactRow').innerHTML = xhr.responseText;
      }
 
 
});

PHP redact.php:
//Здесь выводятся данные на основании переданного из JS id
PHP
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
while($row=mysqli_fetch_assoc($result)){
 
    echo "<tr class='redactTRTH'>";
    echo "<th class='redactTH' >Даты</td>"    ;
    echo "<th class='redactTH'>Наименование</th>"    ;
    echo "<th class='redactTH'>Сумма</th>"    ;
    echo "<th class='redactTH'>Количество</th>"    ;
    echo "<th class='redactTH'>Итого</th>"    ;
    echo "<th class='redactTH'>Статус</th>"    ;
 
 
    echo "</tr>";
 
 
    echo "<tr class='redactTR'>";
    echo "<td class='redactTR' >".$r=$row['date']."</td>"    ;
    echo "<td class='redactTR'>".$d=$row['name']."</td>"    ;
    echo "<td class='redactTR'>".$d=$row['amount']."</td>"    ;
    echo "<td class='redactTR'>".$d=$row['count']."</td>"    ;
    echo "<td class='redactTR'>".$d=$row['total_amount']."</td>"    ;
    echo "<td class='redactTR'>".$d=$row['status']."</td>"    ;
 
 
    echo "</tr>";
    
  
    
    
 
 
}
    echo  "</table>";
    echo "<form method='POST' action='redactRows' onsubmit= 'retur false'>";
    echo "<tr class='redactTR'>";
    echo "<input class='redactTD' type='text' value='".$r=$row['date']."' >" ;
    echo "<input class='redactTD' type='text' value='".$r=$row['date']."' > " ;
    echo "<input class='redactTD' type='text' value='".$r=$row['date']."' > ";
    echo "<input class='redactTD' type='text' value='".$r=$row['date']."'> "  ;
    echo "<input class='redactTD' type='text' value='".$r=$row['date']."' > " ;
    echo "<input class='redactTD' type='text' value='".$r=$row['date']."'> "  ;
    echo "</tr>";
    echo "<input id='perep' type='submit' class='s_copy' value= 'Переписать'>";
    echo "</form>";
 
 
}}


Есть HTML (здесь соответственно :
HTML5
1
2
3
4
    <div id="income" class="income">
     </div>
      <div  id="redactRow" >
     </div>
Есть PHP для дива с id INCOME:

PHP
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
while($row=mysqli_fetch_assoc($result)){
 
    echo "<table class='tablephp' id='tablephp' name='tablephp' class='formReportP'>";
    
    
    echo "<tr ' id='". $row["id"] ."' name='row' class='tr'> ";
 
  
    echo "<td class='chek' id='". $row["id"] ."' ><input type='checkbox' class='checkbox' name='".$row["id"] ."' id='check_row'></td>";
 
    echo "<td id='". $row["id"] ."' name='date'  class='td'>".$date=$row['date']."</td>";
    
    echo "<td id='". $row["id"] ."'  name='name' class='td'>".$name=$row['name']."</td>";
  
    echo "<td id='". $row["id"] ."' name='amount' class='td'>".$amount=$row['amount']."</td>";
 
    echo "<td id='". $row["id"] ."' name='count' class='td'>".$count=$row['count']."</td>";
    
    echo "<td id='". $row["id"] ."' name='total_amount' class='td'>".$total_amount=$row['total_amount']."</td>";
 
    echo "<td id='". $row["id"] ."' name='status' class='td'>".$status=$row['status']."</td>";
 
        
 
    
    echo "</tr>";
    
    echo "</table>";
Проблема:
addEventListener работает по все документу, а должен работать только внутри div'a #income, иначе он идёт передача того, чего не надо.
Перерыл документацию нашёл, что обращаться нужно посредством querySelector, но в этом случае, как понял, addEventListener метод не применим.

Как можно ограничить, чтобы событие срабатывало только внутри таблицы из файла income.php внутри div'a #income?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.08.2019, 12:51
Ответы с готовыми решениями:

Вывод дубликатов с последующим удалением из загружаемой таблицы SQL запросом
Уважаемые Гуру, прошу Вашей помощи, уже неделю пытаюсь решить проблему. По форуму странствовал и подобия не нашёл, может и плохо искал в...

Функция внутри обработчика события?
Что я сделал не так почему выдает ошибку? void __fastcall TForm1::ValueListEditor1StringsChange(TObject *Sender) { void zapis(int...

Не видит состояние внутри обработчика онклик
Что нужно чтобы этот код на ReactJS заработал? Сейчас по нажатии на кнопку возвращает undefined class Test extends React.Component { ...

2
68 / 60 / 10
Регистрация: 07.03.2019
Сообщений: 657
07.08.2019, 13:50
Цитата Сообщение от Артемий_124314 Посмотреть сообщение
'
опечатка.
Цитата Сообщение от Артемий_124314 Посмотреть сообщение
echo *"</table>";
* * echo "<form method='POST' action='redactRows' onsubmit= 'retur false'>";
* * echo "<tr class='redactTR'>";
* * echo "<input class='redactTD' type='text' value='".$r=$row['date']."' >" ;
* * echo "<input class='redactTD' type='text' value='".$r=$row['date']."' > " ;
* * echo "<input class='redactTD' type='text' value='".$r=$row['date']."' > ";
* * echo "<input class='redactTD' type='text' value='".$r=$row['date']."'> " *;
* * echo "<input class='redactTD' type='text' value='".$r=$row['date']."' > " ;
* * echo "<input class='redactTD' type='text' value='".$r=$row['date']."'> " *;
* * echo "</tr>";
* * echo "<input id='perep' type='submit' class='s_copy' value= 'Переписать'>";
* * echo "</form>";

это уже не цикл, незнаю после него стоят две }} , возможно цикл в цикле, вы же не показываете полный серверный код.
Цитата Сообщение от Артемий_124314 Посмотреть сообщение
работает по все документу
Правильно , потому что вы сами прописали document

Цитата Сообщение от Артемий_124314 Посмотреть сообщение
файла income.php
а как мы узнаем какой из них income.php, но я догадываюсь вот это, правильно?
Цитата Сообщение от Артемий_124314 Посмотреть сообщение
Есть PHP для дива с id INCOME:
0
0 / 0 / 0
Регистрация: 25.07.2019
Сообщений: 25
07.08.2019, 14:25  [ТС]
server_net

Зачем Вам полный серверный код? Я его представил для общего понимания(всё что там делается это:получение через $_POST id элемента, по которому произошёл клик; затем подключение к серверу; SQL запрос и получение ответа), основной вопрос
addEventListener работает по все документу, а должен работать только внутри div'a #income, иначе идёт передача того, чего не надо.
Перерыл документацию нашёл, что обращаться нужно посредством querySelector, но в этом случае, как понял, addEventListener метод не применим.

Как можно ограничить, чтобы событие срабатывало только внутри таблицы из файла income.php внутри div'a #income?
server_net
Правильно , потому что вы сами прописали document
Спасибо, за внимательность. Но я уже написал в вопросе о понимании, что это не то)

Добавлено через 16 минут
В общем, решил сам через проверку внутри функции метода addEventListener.
Мол: если кликнули вне элемента с классом .tr, то передаётся id равный нулю, а если внутри, то через .target.id определяем id этого элемента, в моём случае строки, и передаём дальше в обработчик.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.08.2019, 14:25
Помогаю со студенческими работами здесь

Вызвать обработчик события внутри другого обработчика
У окна есть обработчик Loaded=&quot;Window_Loaded&quot;, который мониторит состояние всего окна. Нужно чтобы Window_Loaded смотрел какой контрол...

Задержки на SysTick внутри обработчика прерывания, дребезг
Доброго времени суток. 1. Пытаюсь прикрутить delay на SysTick. При вызове из main все работает корректно, но стот же вызвать из...

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

Передача переменной из обработчика события
Доброго времени суток! Есть метод, который при возникновения события comboBox1.SelectedIndexChanged записывает выделенный элемент...

ComboBox можно-ли изменить свойство Text внутри обработчика onChange этого-же ComboBox-а
Хочу сделать так. var //глобальные sCBoxIni: String = 'Выберите'; .......... procedure TForm1.CBox1Change(Sender: TObject);...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
YAFU@home — распределённые вычисления для математики. На CPU
Programma_Boinc 20.01.2026
YAFU@home — распределённые вычисления для математики. На CPU YAFU@home — это BOINC-проект, который занимается факторизацией больших чисел и исследованием aliquot-последовательностей. Звучит. . .
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru