• ベストアンサー

CSSでのリンク指定(?)

現在、外部CSSで、<h1>タグの背景にタイトル画像を表示するように設定しています。 HTML上の<h1>タグ内では、タイトルに値するテキストを入れていますが、ブラウザの表示できない所においやってあります。 その表示されているタイトル画像(h1で表示している部分)に他ページへのリンクを設定したいのですが、こうした場合のリンク設定はどのようにすればよろしいのでしょうか? CSS内で設定することは可能なのでしょうか? それとも、HTML上でなんらかの形でリンク設定を行うものなのでしょうか? よろしくお願いいたします。

質問者が選んだベストアンサー

  • ベストアンサー
  • taba
  • ベストアンサー率61% (349/567)
回答No.3

そもそも文字を表示されないところにおいやっているという考え方は間違っていますね。でも、正直画像を表示したいときは悩ましいです。私も同じようなケースで、少し調べたりして、今のところこんなやり方をしています。参考までに。 <h1><a href="url"><span>タイトル</span></a></h1> CSS側では、 h1 a{  display:block;  width:適宜;  height:適宜;  background: url(http://~) no-repeat 0px 0px; } h1 a span{  display:none; } こんな感じです。span自体はマークアップ上不適切だとは思うんですが、これが今のところ一番ましなのではないかと思っています。 Aタグの背景に画像を入れていて、それをブロック化しているので、画像サイズと一致させれば違和感はないと思います(背景画像はリンクの対象になりません)。

ponppp
質問者

お礼

なるほど! ありがとうございました。

その他の回答 (2)

  • UKY
  • ベストアンサー率50% (604/1207)
回答No.2

そもそもなぜタイトル画像が CSS で表示されるようになっているのでしょうか。 たとえ画像とはいえタイトルという文書の重要な構成要素が「スタイル」に過ぎないのはどうかと思います。 文書の一部なのですから、<img> などによって文書そのものに含まれているべきだと思うのですが。 > CSS内で設定することは可能なのでしょうか? CSS はあくまでもスタイルシート、見た目をいじくるための代物に過ぎません。 文書内にリンクを生成するには、文書そのもの (HTML) を書き換える必要があります。

ponppp
質問者

お礼

ありがとうございました。

回答No.1

普通に <a href="**.html"><h1 style="background-image: url(**.gif);"></h1></a> でH1全体がリンクされると思いますが・・・

ponppp
質問者

お礼

ご回答ありがとうございます! h1全体にリンクをかけますと、 IEでいえば、通常リンク指定のある画像の上に、マウスをオーバーすると、「指マーク」にカーソルが変更すると思うのですが、 h1に背景画像を設定して、h1全体にリンクをかけると、 カーソルに変化がないようなのですが、こちらは何らかの設定によるものなのでしょうか? お手数をおかけして申し訳ありませんが、よろしくお願いいたします

関連するQ&A