🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

1回答

512閲覧

(Javascript/jQuery) 画像を切り替えるホバーアクションが実現できません。

Anana

総合スコア1

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2021/02/21 16:20

質問内容

複数並ぶ画像を作成ギャラリーを作成しています。

実装としては、画像ホバーをすると他の画像を切り替えるアクションをjQueryで実現したいです。
そのために、以下の CSS HTML Javascript を準備しました。
画像は position:absolute で重ねて、表示・非表示を設定しています。

2枚の画像があるのですが
上の画像 ⇨ ホバーしたら出現 opacity:1 になる
下の画像 ⇨ 上の画像をホバーしたら opacity:0 になる

しかし、以下のコードでは、ホバー時に並んでいる画像の全ての画像までもが opacity;0 になってしまいます。
理想のアクションは、ホバーをした画像のみが opacity:0 になることです。

よろしくお願いします。

ソースコード

HTML

1<div> 2 <div> 3 <div class="image-box"> <a><span class="tt-img"> 4 <img src="#"> 5 </span><span class="imgArea"> 6 <img src="#"> 7 </span> 8 <span> 9 Sale 10 <span> 11 </span></span></span> 12 </a></div> 13 <div> 14 <div> 15 <ul> 16 <li>‥</li> 17 </ul> 18 </div> 19 <h2> text </h2> 20 <div><span>text</span><span> 21 <ul><li>text</li></ul> 22 23</div> 24<div><div> 25 </div> 26 </div></div> 27 <div> 28 </div></div> 29</div>

css

1.img-remove { 2opacity:0 !important; 3} 4 5.opacity {} 6 7.img-roll-over { 8 position: absolute; 9 top: 0; 10 left: 0; 11 opacity: 0; 12 z-index: 1; 13 width: 100%; 14 -webkit-transition: opacity 0.3s ease-out; 15 transition: opacity 0.3s ease-out; 16} 17 18.img { 19 -webkit-transition: opacity 0.3s ease-out; 20 transition: opacity 0.3s ease-out; 21 overflow: hidden; 22 top: 0; 23 left: 0; 24}

jQuery

1$(document).ready(function() { 2$( ".imgArea",).hover( 3function() { 4$(this).addClass('opacity'); 5$('.img').addClass('img-remove'); 6}, function() { 7$(this).removeClass('opacity'); 8$('.img').removeClass('img-remove'); 9} 10); 11}); 12

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

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

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

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

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

guest

回答1

0

ベストアンサー

HTMLの開始タグと終了タグの対応がおかしかったり、CSSの.opacityの中身がなかったりで、正常に動作しないものを見せられても回答しようがないです。

とりあえずホバーで画像を入れ変えるなら、jQuery使わなくもCSSだけで可能です。

HTMLも無意味に複雑なのでシンプルに書き換えてサンプルを作成しましたのでご参考に。

html

1 <div class="image-box"> 2 <a> 3 <div class="imageArea"> 4 <img src="https://picsum.photos/seed/1/400/300"> 5 <img class="img-roll-over" src="https://picsum.photos/seed/2/400/300"> 6 </div> 7 <div> 8 Sale 9 </div> 10 </a> 11 </div>

css

1.imageArea { 2 position: relative; 3 overflow: hidden; 4} 5img { 6 transition: opacity 0.3s ease-out; 7} 8.img-roll-over { 9 position: absolute; 10 top: 0; 11 left: 0; 12 opacity: 0; 13} 14.imageArea:hover img { 15 opacity: 0; 16} 17.imageArea:hover .img-roll-over { 18 opacity: 1; 19}

投稿2021/02/22 00:10

hatena19

総合スコア34073

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

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

Anana

2021/02/22 10:47

失礼しました。 ご回答いただき、ありがとうございました。 いただいたCSSで解決することができました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問