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

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

新規登録して質問してみよう
ただいま回答率
87.20%
CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

解決済

cssで三角形の区切りを作りたい

kjshdfiuasye
kjshdfiuasye

総合スコア23

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

2回答

0評価

0クリップ

365閲覧

投稿2022/01/14 06:12

前提・実現したいこと

cssでどの画面幅でも角度を維持した、直角三角形の区切りを作りたい。ただし、直角三角形の斜線部分の上下位置は、画面幅を変えても動かしたく無い。
イメージ説明
画面幅小(1000px)の時に直角三角形の図で言う上辺が親要素(.parent)の上端にピッタリ付くようにしたい。それ以上の画面幅であれば、直角三角形の図で言う上辺が親要素(.parent)の上端をどんどん上にはみ出すようにしたい。(はみ出た部分はoverflow:hidden;で対処予定)

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

直角三角形の斜線部分の上下位置が画面幅を動かすとずれていってしまう。

該当のソースコード

svg

<?xml version="1.0" encoding="utf-8"?> <!-- Generator: Adobe Illustrator 26.0.2, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> <svg preserveAspectRatio="none" version="1.1" id="レイヤー_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 100 100" style="enable-background:new 0 0 100 100;" xml:space="preserve"> <polygon points="0,100 0,0 100,0 "/> </svg>

html

<div class="parent"> <div class="skewed_wrap2"> <div class="skewed_wrap"> <img src="img/triangle.svg" alt="" class="skewed" width="100" height="100"> </div> </div> </div>

css

html, body { height: 100%; } .parent{ position: relative; padding-top: 1200px; background-color: red; } .skewed_wrap2 { position: absolute; top: 0; left: 0; width: 100%; height: 100%; } .skewed_wrap { position: relative; width: 100%; padding-top: calc(100% * 0.087488663525924); /*0.087488663525924=直角三角形角度5度の時のタンジェント*/ } .skewed { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0.5; }

三角形を作るために試したこと

・linear-gradient
・border
・svg
・skew
・rotate

上下位置を保つために試したこと

・background-position
↑svgを背景画像にしてcenter centerにしたところ位置を維持できたが、親要素の上端にぴったりつかない。

直角三角形を数式で表すために試したこと

https://keisan.casio.jp/exec/system/1259903491
https://keisan.casio.jp/exec/system/1260261251

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。