質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

1回答

464閲覧

[jQuery]別のclick,functionで作成した変数を使って、要素を削除する方法

after.noon.tea

総合スコア1

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2021/03/23 14:13

編集2021/03/24 02:23

前提・実現したいこと

1つのモーダルで、3つの情報を切り替えをしたい為、下記を行っております。

・各ボタン(.btn)をクリックした際、モーダルを展開させながら、モーダル部にカスタムデータ属性(data-id)を付与させる。

・モーダル内の閉じるボタンをクリックした際、モーダルに付与されたカスタムデータ属性(data-id)を削除したい(ボタンを押す度にクラスがたくさんでてくる為)。

・ボタン1をクリックした場合
モーダルが展開しつつ .modal--block に対し、カスタムデータ属性 data-id="1" と クラスdisplayを付与し、モーダル内に<p class="test">テスト1テスト1</p>を表示させる

.modal--block 内の閉じるボタンをクリックした際、付与されているdata-idを削除

発生している問題・エラーメッセージ

変数がナンバリングしている為、removeClassで指定ができない為、クラスを削除できない。
その為、別のfunctionで指定した変数を持ってこれないか。
他の方法でも削除できるのでしたら、ご教授頂きたいです。

コード

html

1<div class="btn-list"> 2 <button class="open-btn" data-id="1">ボタン1</button> 3 <button class="open-btn" data-id="2">ボタン2</button> 4 <button class="open-btn" data-id="3">ボタン3</button> 5</div> 6 7<div class="modal--block"> 8 <p>テキスト</p> 9 <button class="close">閉じるボタン</button> 10</div>

js

1$('.open-btn').on('click',function(){ 2 3 //クリックしたボタンのデータの取得 4 var sample = $(this).data('id'); 5 6 //クリックしたデータ属性を modal--blockに付与 7 $(this).parents('.btn-list').next('.modal--block').data('id', sample); 8 9 //modal--block のデータ取得 10 var sample2 = $(this).parents('.btn-list').next('.modal--block').data('id'); 11 12 13 var i = sample2; 14 var display = ('display'+i); 15 16 17 //受け取ったデータ番号をクラス display に追加 18 $(this).parents('.btn-list').next('.modal--block').addClass(display); 19 i++; 20 21 //出しわけたいテキスト 22   $(this).parents('.btn-list').next('.modal--block.display1').html('<p class="test">テスト1テスト1</p>'); 23 24   $(this).parents('.btn-list').next('.modal--block.display2').html('<p class="test">テスト2テスト2</p>'); 25 26   $(this).parents('.btn-list').next('.modal--block.display3').html('<p class="test">テスト3テスト3</p>'); 27 28 29}); 30 31//モーダルを開く 32$('.btn').on('click',function(){ 33 $(this).parents('.btn-list').next('.modal--block').fadeIn(); 34}); 35 36 37//モーダルを閉じる 38 $('.close').on('click',function(){ 39 $('.modal--block').fadeOut(); 40 });

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yambejp

2021/03/24 00:55 編集

具体的になにをどうしたらどういう結果になるのを期待してるのか説明してください sampleというクラスのついたHTML要素が見当たりません またopenというHTMLタグも見当たりません
after.noon.tea

2021/03/24 02:24

ご指摘ありがとうございます。 クラスの間違えを修正し、説明を具代的に書き直しました。
guest

回答1

0

ベストアンサー

javascript

1<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script> 2<link rel="stylesheet" href="https://code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css" /> 3<script src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script> 4<script> 5$(function(){ 6 $('.modal--block').hide(); 7 $('.btn').on('click',function(){ 8 $('.modal--block').dialog({modal:true,buttons: { 9 "閉じる": function() { 10 $(this).dialog("close"); 11 $(this).attr("data-id",null); 12 }, 13 }}).attr('data-id',$(this).attr('data-id')); 14 }); 15}); 16</script> 17<div class="btn-list"> 18 <button class="btn" data-id="1">ボタン1</button> 19 <button class="btn" data-id="2">ボタン2</button> 20 <button class="btn" data-id="3">ボタン3</button> 21</div> 22 23<div class="modal--block"> 24<p>テキスト</p> 25</div> 26

投稿2021/03/24 02:21

編集2021/03/24 02:27
yambejp

総合スコア114848

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yambejp

2021/03/24 02:27 編集

jQueryを利用する前庭であればjQueryUIのdialogを利用するのが楽です 肝心のdata-idを削除し忘れてたので修正しておきました
after.noon.tea

2021/03/24 02:46

ありがとうございます。 問題なく動きました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問