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

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

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

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

Q&A

解決済

2回答

1021閲覧

jQueryコードを短くまとめたい

momocan

総合スコア13

jQuery

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

0グッド

0クリップ

投稿2019/06/10 07:15

サムネイルをクリックすると画像が切り替わるjQueryです。
同じページに複数設置したいのですが、コードを短く簡潔にまとめたいです。
ご教示ください。宜しくお願いします。

HTML

1<div class="mainimage1"> 2<img src="/gazou01.jpg" alt="画像1"> 3</div> 4 <div class="thumbnail1"> 5 <img src="gazou01.jpg" alt="画像1"> 6 <img src="gazou02.jpg" alt="画像2"> 7 <img src="gazou03.jpg" alt="画像3"> 8</div> 9 10<div class="mainimage2"> 11<img src="/gazou04.jpg" alt="画像4"> 12</div> 13 <div class="thumbnail2"> 14 <img src="gazou04.jpg" alt="画像5"> 15 <img src="gazou05.jpg" alt="画像6"> 16 <img src="gazou06.jpg" alt="画像7"> 17</div>

jQuery

1$(function(){ 2 $('.thumbnail1 img').click(function(){ 3 var $thisImg = $(this).attr('src'); 4 var $thisAlt = $(this).attr('alt'); 5 $('.mainimage1 img').attr({src:$thisImg,alt:$thisAlt}); 6 }); 7 $('.thumbnail2 img').click(function(){ 8 var $thisImg = $(this).attr('src'); 9 var $thisAlt = $(this).attr('alt'); 10 $('.mainimage2 img').attr({src:$thisImg,alt:$thisAlt}); 11 }); 12});

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

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

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

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

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

guest

回答2

0

ベストアンサー

サムネイルと通常画像のsrcが一緒なのでしょうか?
スラッシュ付きとそうでないのは実はパスが異なるのでしょうか?

javascript

1<script> 2$(function(){ 3 $('.thumbnail img').on('click',function(){ 4 $(this).closest('.thumbnail').prev('.mainimage').find('img').attr({ 5 src:$(this).attr('src'), 6 alt:$(this).attr('alt'), 7 }); 8 }); 9}); 10</script> 11 12<div class="mainimage"> 13<img src="/gazou01.jpg" alt="画像1"> 14</div> 15 <div class="thumbnail"> 16 <img src="gazou01.jpg" alt="画像1"> 17 <img src="gazou02.jpg" alt="画像2"> 18 <img src="gazou03.jpg" alt="画像3"> 19</div> 20 21<div class="mainimage"> 22<img src="/gazou04.jpg" alt="画像4"> 23</div> 24 <div class="thumbnail"> 25 <img src="gazou04.jpg" alt="画像5"> 26 <img src="gazou05.jpg" alt="画像6"> 27 <img src="gazou06.jpg" alt="画像7"> 28</div>

投稿2019/06/10 07:25

yambejp

総合スコア114585

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

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

momocan

2019/06/10 08:43

スラッシュは書き忘れです。すみません。 ありがとうございました。
guest

0

HTML

1<div class="thumbnail thumbnail1">

となっているものとして

jQuery

1 $('.thumbnail').on('click', 'img', function(event) { 2 var img = $(this); 3 img.parent().prev().find('img').replaceWith(img.clone(false)); 4 });

投稿2019/06/10 07:31

x_x

総合スコア13749

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問