html
1<%@ page language="java" contentType="text/html; charset=UTF-8" 2 pageEncoding="UTF-8"%> 3 <%@ page import="java.util.ArrayList"%> 4<!DOCTYPE html> 5<html> 6<head> 7<meta charset="UTF-8"> 8<title>住所一覧</title> 9<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script> 10</head> 11<body> 12 13<table border="1"style="border: 1px solid black; border-collapse: collapse;"> 14<%ArrayList<String> address = (ArrayList<String>) session.getAttribute("result");%> 15<%ArrayList<String> post = (ArrayList<String>) session.getAttribute("post");%> 16<%ArrayList<String> adid = (ArrayList<String>) session.getAttribute("adid");%> 17<%int i=0;%> 18<%int j=0;%> 19<tr> 20<th class="th1">郵便番号</th> 21<th class="th2">住所</th> 22</tr> 23<%for(String addr : address){ %> 24<tr> 25<td class="th1"> 26 27<%=post.get(i)%> 28</td> 29<td class="th2"> 30<a href=""><%=addr%></a> 31</td> 32<td> 33<form action="<%=request.getContextPath()%>/Addr_delete" id="delete" method="post"> 34<input type="hidden" name="delete_id" value="<%=adid.get(j)%>"> 35<button type="submit" name="button" id="button123" class="inline-block">削除</button> 36</form> 37</td> 38</tr> 39<%j++;%> 40<%i++;%> 41<%}%> 42<tr class="tr3"> 43<td colspan = "2" align="center"> 44<form action="address_add.jsp" method="get"> 45<button type="submit" name="button1" >追加</button> 46</form> 47</td> 48</tr> 49</table> 50<form action="success.jsp" method="get"> 51<button type="submit" name="button2">戻る</button> 52</form> 53<form action="addr_delete.jsp" method="get"> 54<button type="submit" name="button3">住所削除</button> 55</form> 56<form action="addr_update.jsp" method="get"> 57<button type="submit" name="button4">住所更新</button> 58</form> 59<script> 60let button = document.getElementById('button123'); 61button.addEventListener('click', function() { 62 if(window.confirm('本当に削除しますか')){ 63 document.getElementById('delete').submit(); 64 return; 65 } 66}); 67 68</script> 69</body> 70</html>
<button type="submit" name="button" id="button123" class="inline-block">削除</button>
ここの削除ボタンが押されたときに、'本当に削除しますか'と確認ダイアログボックスを出して、はい だった場合に
document.getElementById('delete').submit();で 'delete' id のformを送信したいと考えております。
実際に実行して削除ボタンを押してみると、確認ダイアログボックスが表示されず削除されてしまいます。
Chromeの検証(デベロッパーツール)で見てみると
Uncaught TypeError: Cannot read property 'addEventListener' of null
at Userlist?button3=:31
このようなエラーが出ています。
<script>は bodyの一番下に記述しています。 一人では解決することが出来なかったので、アドバイス頂けると助かります。 ---追記-- ```html <form action="<%=request.getContextPath()%>/Addr_delete" id="delete" method="post" onsubmit="return click()"> <input type="hidden" name="delete_id" value="<%=adid.get(index)%>"> <button type="submit" name="button" id="button123" class="inline-block">削除</button> </form> <script> let button = document.getElementById('button123'); button.addEventListener('click', function click() { if(window.confirm('本当に削除しますか')){ return false; }else{ return true; } }); </script>1.調べて上記のコードを書いてみましたが、上記のコードでも上手くいきません 2.<button type="submit" name="button" id="button123" class="inline-block">削除</button> のコードの type=button とすると送信も javascriptも実行されなくなります。
回答3件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/09/11 01:31