jquery を使い要素の追加削除をおこないたいです
html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> div { padding: 0.5em 0.5em; margin: 2em 3rem; font-weight: bold; border: solid 3px #000000; } .kanagata p { margin: 0; padding: 0; } </style> </head> <body> <div class="main"> <div class="kanagata"> <p>たいやきマシーン</p> <button class="ryousan">量産!</button> </div> </div> <script src="https://code.jquery.com/jquery-3.4.0.min.js"></script> <script> $(function() { $(".ryousan").click(function() { const taiyaki = $(document.createElement('div')); $(taiyaki).addClass("taiyaki") $(taiyaki).html('<p>おいしいたいやき!</p>'); $(this).parent().before($(taiyaki)); }); const haikiBtn = $(document.createElement('div')); $(haikiBtn).addClass("haiki").html("<button>廃棄…</button>"); $('.main').on('mouseover', '.taiyaki' , function() { $(this).append($(haikiBtn)); }); // ----------------------------------------------------- $('.main').on('mouseout', '.taiyaki.haiki' , function() { // ----------------------------------------------------- $(haikiBtn).remove(); }); $('.main').on('click', ".haiki", function() { $(this).parent().remove(); }); }); </script> </body> </html>
余計な要素に乗ってるときはイベントを起こさないようにしたいです
各たいやきにボタンを追加、削除はできたのですが、他の要素(main内、かつtaiyaki外)に乗ってる時もボタンが残ってしまいます。こういう時はどうすればよいのでしょうか?
まだ回答がついていません
会員登録して回答してみよう