前提・実現したいことと問題点
こちらの記事を参考に「クリックして開くツールチップ」を作っています。
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;
をつけてみたりもしましたがダメでした。。
どなたかお知恵を貸していただけますと助かります。
どうぞよろしくお願いします。
回答1件
あなたの回答
tips
プレビュー