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

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

07.08.2019, 12:51. Показов 603. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит значение перечислений. / / Событие "НачалоВыбора" реквизита на форме. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru