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

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

ただいまの
回答率

90.51%

  • HTML5

    5118questions

    HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

skipprにリンクを貼る方法

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 702

area246

score 4

初心者なんですが、skipprというフリーのスライドが素敵だったので、これのhtmlから順番に見て、試しにデータをいじってみています。

このスライドですが、htmlでスライドをさせる既述を書いているみたいですが、この各写真に他のページを開くurlを書き込みたいんですが、htmlに書くのかcssに書くのかわかりません。しかも、cssに書くにしても、スライドさせている絵の特定はhtmlで行っているので、このような場合はどのようにするのがベストなのでしょうか。
一般的なスライドショーはcssでimgの指定も動作も指定しているのが普通のようですので、ちょっと困惑しています。

skipprのhtml

<div id="container">
            <div id="theTarget">
                <div style="background-image: url(img/image1.jpg)"></div>
                <div style="background-image: url(img/image2.jpg)"></div>
                <div style="background-image: url(img/image3.jpg)"></div>
                <div style="background-image: url(img/image4.jpg)"></div>
                <div style="background-image: url(img/image5.jpg)"></div>
            </div>    
        </div>

例えば、このhtmlのスライド1枚目のimage1.jpgのリンク先がimage1.htmlだった場合に、そのページに飛ぶようにしたいと考えています。通常だと、
<a href="image1.htmlなどのリンク先url">image1</a>

となりますが、これをhtml上に配置しようとするにもdivの中に入れられない?ようですし、divの外に書いてしまうとスライドが成り立たなくなってしまいます。<div></div>の間に既述する必要があるとは思いますが、
<div style="background-image: url(img/image1.jpg);"><a href="#">image1</a></div>

にすると、画面の上にimage1というリンクが貼られた文字が表示されるだけで絵全体にリンクは貼れませんし、
<a href="#"><div style="background-image: url(img/image1.jpg);"></div></a>

と、<a>で囲ってみると、image1だけ白紙になってしまいます。
<div style="background-image: url(img/image1.jpg);" href="#">
なども試してみましたが違うようです。

深く考えすぎなのか、難しいのか簡単なのかさっぱりわかりません。
お分かりになる方がいらっしゃれば是非教えて下さい。

skippr
http://on-ze.com/archives/1797

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • mts10806

    2017/06/21 14:19

    できてますね。よかったです。・・・お手数ですがコード部分は```で囲っていただけると助かります(分からなければコード部分を選択して<code>ボタンを押してください)

    キャンセル

  • area246

    2017/06/21 14:28

    何度もすみません。私のような初心者が利用するようなサイトではないですよね。申し訳ありません。この件までは質問してしまったので、このままお願いできればと思います。

    キャンセル

  • mts10806

    2017/06/21 14:49

    利用するのは初心者かどうかは関係ないと思いますよ。むしろ初心者こそどんどん使って課題を解決していき技術を身につけていくべきと思います。「初心者アイコン」も用意されていますし。色々な使い方があって良いと思います。

    キャンセル

回答 1

checkベストアンサー

+1

少し回答までお時間いただいてしまいましたが、
以下の方法をお試しください。

  • スライドにリンクを挿入
<div style="background-image: url(img/image1.jpg)"><a href="image1.html">&nbsp;</a></div>


※&nbsp;は「半角スペース」で、本来はなくてもいいかもしれませんが、ひとまず

  • リンクに対して下記を設定
#theTarget div a{
display:block;
width:XXXpx;
height:YYYpx;
}


※height,widthのXXX,YYYはスライド画像の大きさにあわせてください。
範囲が分かりづらい場合はbackground-colorなどを設定して調整してみてください。

解説:
<a>タグをブロック化することでdivの範囲内で文字を入れなくてもクリック可能しています。

蛇足:
これを応用してpositionも併用すると、例えば「背景画像の中の任意の箇所をクリックする」といったことが可能となります。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/06/21 17:14

    やはりhtml上だけではリンクは貼ることができないようですね。
    CSSも早く勉強しなければ。<a>はやはりdivの中に入れるという考え方で間違いはなかったようですが、文字を入れてしまっていたので特にわからなくなっていたようです。
    CSSのpositionというのは調べていた時にヒットして見てはいたのですが、何分まだCSSもわからない状況ですのでスルーしていました。
    ちょっと試してみます。
    このような質問にご回答下さりありがとうございました。

    キャンセル

  • 2017/06/21 17:24

    今回の要件だけだとpositionは必要なさそうなので完全に蛇足です。
    例えば日本地図のような背景画像を1つ用意して各都道府県のリンクをつけたいようなときはaタグをブロック化してpositionとtop,leftとかを駆使してaタグを置きたいエリアに置くような形をします。
    まあ、htmlとcss、ついでにjavascriptは家族みたいなもので駆使することでWebページが形になっていくので、簡単なものから覚えていくと良いと思いますよ。
    例えば今回の場合、javascriptのクリックイベントを上手いこと利用すればaタグ置かずに画面遷移も可能になると思います。
    結果は同じでも実に様々なやり方が出来るのでその中で自分に合ったやり方とかより良いやり方を身につけていくといいですね。

    キャンセル

  • 2017/06/21 17:41 編集

    かなり甘く見ていました・・・簡単に「絵にリンクを貼れば飛ぶでしょ」位に思っていたのですが、書いてみると全然・・・
    確かにひとつの動作をさせるのに、いくつもの方法があるということも分かってきました。やってみないと分からないですね。分からないので調べてみると、いろんな説明があったりするので、益々分からなくなってきたり(苦)
    一応は簡単なhtmlから入ったのですが、次にskipprという見た目から入ってしまったので失敗しました。

    ちなみに、今試してみているところですが、リンクが貼れていないようで・・・ビルダーを使っていますが、ページ編集をみると、半角スペースを取った部分に小さなアンダーラインは入っているものの、絵全体にリンクが貼れていないようです。

    .hero{
    width: 100%;
    height: 100%;
    min-height: 500px;
    position: relative;
    }
    #theTarget div a{
    display: block;
    width: 100%;
    height: 100%;
    }
    とcssに書いてみましたが、多分htmlのほうの不具合でしょうか。

    気になってしまったので、これにリンクが貼れるまで頑張ってみようと思います。その後で仕切り直して簡単なものを作ってみようと思います。

    本当にすみませんでした。ありがとうございました。

    キャンセル

  • 2017/06/21 18:43

    背景画像にすると実態は目に見える場所にはないですからね・・・。以前、私も苦労しました。
    width、heightは100%にするより表示されているスライドのサイズ(画像のサイズ)に合わせた方がいいと思います。
    <a>タグ内(ひいては<div>タグ内)には実際は何もない状態なので%表示にすると空の状態なのでブロックは広がりません。#theTarget divにheight,widthを指定したらきくかもしれません。

    キャンセル

同じタグがついた質問を見る

  • HTML5

    5118questions

    HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。