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

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

詳細はこちら
JavaScript

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

Q&A

解決済

1回答

6411閲覧

「クリックして開くツールチップ」の中にテキストリンクを入れたい

nyrrrr

総合スコア10

JavaScript

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

0グッド

0クリップ

投稿2019/12/08 05:26

編集2019/12/09 07:12

前提・実現したいことと問題点

こちらの記事を参考に「クリックして開くツールチップ」を作っています。
https://qiita.com/mrd-takahashi/items/4f27927ced6275b16969

クリックして開き、またクリックすると隠れる、という仕様のツールチップです。
表示まではできたのですが、
さらにツールチップの中のテキストにリンクを付けたい。というところで詰んでしまいました。

※hoverタイプにすることや、閉じるボタンを加えることは極力したくないです...

該当のソースコード

jsの最後の方にある「表示されたツールチップを隠す処理(マウスクリックで全て隠す)」が、
リンクのクリックも無効にしてしまっている、というところまではわかりましたが、
どうすればクリックできるのか...

html

1<div class="con"> 2 <a href="#note1" class="clickToolTip"><img src="images.png"></a> 3 <p id="note1" class="toolTip invisible"> 4   <a href="index.html">テキストリンク</a></a> 5 </p> 6</div>

css

1.invisible{ 2 display: none; 3} 4 5a.clickToolTip{ 6 margin: 0; 7 padding: 2px 6px; 8 text-decoration: none; 9 color: #fff; 10 font-size: 12px; 11} 12p.toolTip{ 13 margin: 0; 14 padding: 1em; 15 width: 70%; 16 background-color: #a92524; 17 -moz-border-radius: 5px; 18 top: 100px; 19 left: 0; 20 position: absolute; 21 z-index: 50; 22 font-size: 1rem; 23 line-height: 1.8; 24 font-weight: bold; 25}

js

1$(function(){ 2 // ツールチップ表示処理 3 $('a.clickToolTip').click(function(){ 4 // リンクの #note** を取得 5 var targetNote = $(this).attr('href'); 6 7 // [?]の座標を取得 8 var position = $(this).position(); 9 var newPositionTop = position.top +10; /* + 数値で下方向へ移動 */ 10 var newPositionLeft = position.left + 35; /* + 数値で右方向へ移動 */ 11 12 // ツールチップの位置を調整 13 $('p'+targetNote).css({'top': newPositionTop + 'px', 'left': newPositionLeft + 'px'}); 14 15 // ツールチップの class="invisible" を削除 16 $('p'+targetNote).removeClass('invisible'); 17 }); 18 19 // 表示されたツールチップを隠す処理(マウスクリックで全て隠す) 20 $('html').mousedown(function(){ 21 $('p.toolTip').addClass('invisible'); 22 }); 23 // aクリックを無効 24 $('a.clickToolTip').click(function(){ 25 return false; 26 }); 27});

試したこと

javascriptはからっきしのためcssで無理やりどうにかできないかと、aタグに

position: absolute; z-index: 100;

をつけてみたりもしましたがダメでした。。

どなたかお知恵を貸していただけますと助かります。
どうぞよろしくお願いします。

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

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

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

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

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

m.ts10806

2019/12/08 05:40

装飾部分もきちんと提示された方が良いと思います。 本当にその部分に問題ないのか誰も判断できませんし、実際やっていることが再現できません。 お手元のコードをご提示ください。
nyrrrr

2019/12/08 05:50

そうですね、失礼いたしました。 css追記いたしました。
guest

回答1

0

ベストアンサー

JavaScript

1 //$('html').mousedown(function(){ 2 $('html').click(function(){

投稿2019/12/09 02:55

x_x

総合スコア13749

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

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

nyrrrr

2019/12/09 06:03

ご回答ありがとうございます! ですが、ツールチップが表示されなくなってしまいました...
x_x

2019/12/09 06:07

表示されないのは元からだと思いますよ。提示コードと参考サイトを比べてみてください。
nyrrrr

2019/12/09 07:08

!!! 提示していたHTMLが間違えていました。。target ではなく href ですね。 教えていただきありがとうございます。 無事テキストリンク押せるようになりました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問