前提・実現したいこと
①Todoリストで、追加ボタンを押すとID(インデックス)、タスク、作業中、削除ボタンの4つがtdタグに順次追加されるようにしたい
②削除ボタンを押したらタスクが消えて、インデックスが初期化されているようにしたい
発生している問題・エラーメッセージ
①タスクを追加すると、下に追加されていくのではなく、同じ場所でインデックス番号のみ変わっていく仕様になっている。addTaskとaddButtonのオブジェクトは分けて実装したいです。
②初期化のメドッドを用いているが動作しない
該当のソースコード
HTML
1<!DOCTYPE html> 2<html lang="ja"> 3<head> 4 <meta charset="UTF-8"> 5 <meta name="viewport" content="width=device-width, initial-scale=1.0"> 6 <link rel ="stylesheet" href="css/style.css"> 7 <title>Todoリスト</title> 8</head> 9<body> 10 <h1>Todoリスト</h1> 11 <p> 12 <input type="radio" name="status" value="1" checked="checked">全て 13 <input type="radio" name="status" value="2">作業中 14 <input type="radio" name="status" value="3">完了 15 </p> 16<p></p> 17 <table> 18 <thead> 19 <th>ID</th> 20 <th>コメント</th> 21 <th>状態</th> 22 <th></th> 23 </thead> 24 <tbody class ="addTask-target"></tbody> 25 </table> 26 <h2>新規タスクの追加</h2> 27 <input class="addTask-value" type="text" /> 28 <button class="addTask-trigger" type="button">追加</button> 29 <script src="js/main.js"></script> 30</body> 31 32</script> 33</html>
Javascript
1 2 { 3 document.addEventListener('DOMContentLoaded', function() { 4 const addTaskTrigger = document.getElementsByClassName('addTask-trigger')[0]; 5 const addTaskTarget = document.getElementsByClassName('addTask-target')[0]; 6 const addTaskValue = document.getElementsByClassName('addTask-value')[0]; 7 let nextId = 0; 8 const todos = []; 9 10 //テーブル要素を生成する td要素を作る 11 const tableItem = document.createElement('tr'); 12 const idSpanTd = document.createElement('td'); 13 const taskSpanTd = document.createElement('td'); 14 const createButtonTd = document.createElement('td'); 15 const removeButtonTd = document.createElement('td'); 16 17 const addTask = (task, id) => { 18 //要素内のHTML文章を変更する 19 idSpanTd.innerText = id; 20 taskSpanTd.innerText = task; 21 //生成したテーブル要素をブラウザに表示する 22 tableItem.append(idSpanTd); 23 tableItem.append(taskSpanTd); 24 addTaskTarget.appendChild(tableItem); 25 return(task,id) 26 }; 27 28 //Button要素を生成する 29 const removeButton = document.createElement('button'); 30 const createButton = document.createElement('button'); 31 32 const addButton = (button) => { 33 //要素内のHTML文章を変更する 34 createButton.innerText = '作業中'; 35 removeButton.innerText = '削除'; 36 //生成したテーブル要素をブラウザに表示する 37 tableItem.append(createButtonTd); 38 tableItem.append(removeButtonTd); 39 addTaskTarget.appendChild(tableItem); 40 //生成したbutton要素を生成する 41 createButtonTd.append(createButton); 42 removeButtonTd.append(removeButton); 43 return(button) 44 }; 45 46 //追加ボタンをクリックした際にタスクを追加する処理を行う 47 addTaskTrigger.addEventListener('click', () => { 48 const task = addTaskValue.value; 49 addTask(task, nextId++); 50 addButton(); 51 addTaskValue.value = ''; 52 }); 53 54 //チェックリスト用オブジェクト 55 const todo = { 56 task: 'taskSpanTd', 57 status: '作業中' 58 }; 59 todos.push(todo); 60 61 removeButton.addEventListener('click', delete_element, false); 62 63 // //削除ボタンを押した時にタスクを削除する 64 function delete_element () { 65 let tabletag = this.closest ('tr'); 66 if (tabletag) 67 tabletag.remove (); 68 } 69 }); 70 }
試したこと
①addTaskとaddButtonにそれぞれ以下の記述が無いためクリックした際に下に追加されないのではないかと思い、以下の要素を関数にしてaddTaskとaddButtonの中に入れましたが、上手く機能せずでした。
//テーブル要素を生成する td要素を作る const tableItem = document.createElement('tr'); const idSpanTd = document.createElement('td'); const taskSpanTd = document.createElement('td'); const createButtonTd = document.createElement('td'); const removeButtonTd = document.createElement('td');
②以下の関数を使用していますが機能せずです。
// インデックスの初期化 // function initialize() { // if(tr) // tr.initialize(); // }; // document.addEventListener("DOMContentLoaded", initialize.bind(this));
お手数ですがご確認宜しくお願い致します。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/06/24 15:03
2020/06/24 15:13
2020/06/25 08:59