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

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

ただいまの
回答率

87.50%

画面全体を斜めで2分割し、左右それぞれにリンクを貼ることはhtml,cssで実現可能か

解決済

回答 4

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 3,578

前提・実現したいこと

htmlとcssで以下のような画面を構築したいのですが、htmlとcssのみで実現可能でしょうか。

イメージ説明
・画面幅いっぱいで、左右のブロックはデバイスに合わせて伸び縮みする
・ロゴとテキストはブロックの中央に配置
・ブロック全体にリンクを貼る

発生している問題・エラーメッセージ

現在、以下を試しているのですが、余白が生まれるor横並びが崩れてしまい、うまくいきません。

・divを2個transformで傾け、floatで横並び
・さらに外側にdivを設け、overflow:hidden;

ブロックのwidthを小さくすると余白が出てしまい、余白を潰すためブロックのwidthを大きくすると段落ちしてしまう

イメージ説明

該当のソースコード

<body>
<div class="screen">
    <h1><img src="./img/z_logo.png" alt="Z"></h1>
    <div id="t">
        <a href="https://t.co.jp/" target="_blank">
            <div>
                <h2><img src="./img/t_logo.png" alt=""></h2>        
                <hr>
                <p>テキストテキストテキスト<br>
                テキストテキストです<br>
                テキストテキストテキストです</p>
            </div>
        </a>
    </div>
    <div id="e">
        <a href="" target="_blank">
            <div>
                <h2><img src="./img/e_logo.png" alt="e"></h2>
                <hr>
                <p>テキストテキストテキスト<br>
                テキストテキストです<br>
                テキストテキストテキストです</p>
            </div>
        </a>
    </div>
</div>
body{
    width: 100%;
    position: relative;
}
h1{
    position: absolute;
    top:40px;
    left:50px;
    z-index: 1;
}
div.screen{
    width:100vw;
    height:100vh;
    overflow: hidden;
}
div#t,
div#e{
    position: relative;
    background:linear-gradient(#000, #333);
    transform: rotate(20deg);
    width: 637px;
    height: 850px;
    float:left;
}
div#t a div,
div#e a div{
    width: 225px;
    height:175px;
    position: absolute;
    top:0;
    right:0;
    bottom:0;
    left:0;
    margin:auto;
}
div#t a,
div#e a{
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;    
}

お知恵を貸してください><
宜しくお願いいたします。

ーーーーーーー
追記:
hatena19様の方法で横並びにした後に、
ロゴとテキストを中央に持ってくるために、
div#eの中のdivのleft:0;を25%、div#tの中のdivのright:0;を25%に調整しました。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 4

checkベストアンサー

+4

いろいろ方法があると思いますが、
transform: rotate で回転させると余白が上下左右にできるのでそれを埋めるのが面倒なので、
transform: skewで斜め変形させる方法で考えてみました。
参考リンク
SVGやclip-pathは必要なし!平行四辺形のクリッピングマスクをかけてアニメーションさせてみよう

* {
  margin: 0;
  padding: 0;
}
body{
  width: 100%;
  position: relative;
}
h1{
  position: absolute;
  top:40px;
  left:50px;
  z-index: 1;
}
div.screen{
  width:100vw;
  height:100vh;
  overflow: hidden;
  display: flex;
}
div#t,
div#e {
  position: relative;
  background:linear-gradient(to left, #000, #333);
  transform: skew(-20deg) translateX(-25%);
  height: 850px;
  flex: 0 0 65%;
}
div#t a div,
div#e a div{
  width: 225px;
  height:175px;
  position: absolute;
  top:0;
  right:0;
  bottom:0;
  left:0;
  margin:auto;
  transform: skew(20deg);
}
div#t a,
div#e a{
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;    
}


動作確認用Codepenサンプル

div#t, div#eの横並びは、親要素にdisplay: flex;で実現しました。
斜め変形させると左右に余白ができますので、幅を広げてtranslateXで横移動させて余白を隠しました。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2020/03/01 21:09

    お忙しいところ、丁寧なご回答をいただきありがとうございます。
    無事、余白なしで幅いっぱいの斜めブロックを横並びにできました!!

    皆様勉強になりましたが、その中でも一番わかりやすかったのでベストアンサーとさせていただきます。
    ありがとうございました!!

    キャンセル

+3

divを2個transformで傾け、floatで横並び

作りたいイメージからするとtransform:rotate()ではなく、transform:skew()を使った方が適していると思います。
https://developer.mozilla.org/ja/docs/Web/CSS/transform-function/skew

ブロック全体にリンクを貼る

html5で作っているなら、ブロック全体を囲むようにaタグを入れるのが楽です。

ブロックのwidthを小さくすると余白が出てしまい、余白を潰すためブロックのwidthを大きくすると段落ちしてしまう

ブロック2つを囲むdivをもう一つ設けて、段落ちしない幅を設定して、はみ出た分左にずらすと良いかと思います。
このように

.wrapper {
  width: 100vw;
  overflow: hidden;
}
.inner {
  width: 120vw;
  margin-left: -10vw;
}
.block {
  width: 60vw;
}

一通り作ってみました。ご参考までに。
https://codepen.io/w1103h/pen/mdJwRPa

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2020/03/01 21:25

    お忙しいところ、丁寧な回答をいただきありがとうございます。
    段落ちしない方法の他にも、aタグの入れ方・クラスの付け方等、とても勉強になりました。
    無事、余白なしで幅いっぱいの斜めブロックを横並びにできました!!
    見やすいデモ画面も付けていただき、本当にありがとうございました!

    キャンセル

0

http://www.htmq.com/html5/area.shtml

テキストはうまく重ねてください

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2020/03/01 21:13

    お忙しいなか、コメントをいただきありがとうございます。

    せっかくご指摘いただいたのにこちらの知識不足で理解が出来なかったのですが、
    <a>の範囲を広げるのではなく、<area>を使った方が良いということでしょうか?

    キャンセル

0

背景をlinear-gradientで書いてしまえばよいとおもいます。

【linear-gradient() - CSS: カスケーディングスタイルシート | MDN】
https://developer.mozilla.org/ja/docs/Web/CSS/linear-gradient

【【CSS】背景(background)を2色にする | 125naroom / デザインするところ(会社)です。】
https://125naroom.com/web/2838

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2020/03/01 13:44

    > ・ブロック全体にリンクを貼る
    背景の線に沿ってリンク先を分けているようでしたよ。それも実現できそうです?

    キャンセル

  • 2020/03/01 13:56

    To: oikashinoaさん
    そこは読み落としていました。
    a::beforeを回転させて被せたら全体を回すよりは影響が少ないと思います。

    キャンセル

  • 2020/03/01 14:28

    背景の区切りとキッチリ合わせるのは大変そうな気がしますが…一度考えてみます。

    キャンセル

  • 2020/03/01 21:16

    お忙しいところ、ご回答をいただきありがとうございます。
    a::beforeを回転させる案、張っていただいたURLも参考にさせていただきます!

    キャンセル

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

  • ただいまの回答率 87.50%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

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