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

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

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

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

HTML5

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

Sass

Sassは、プログラミング風のコードでCSSを生成できるスタイルシート言語です。 scss ファイルを、変換(コンパイル)してCSSファイルを作成します。

CSS

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

Q&A

解決済

1回答

3777閲覧

変形させた擬似要素が右にはみ出てしまいます。

kogari

総合スコア12

CSS3

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

HTML5

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

Sass

Sassは、プログラミング風のコードでCSSを生成できるスタイルシート言語です。 scss ファイルを、変換(コンパイル)してCSSファイルを作成します。

CSS

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

0グッド

0クリップ

投稿2021/12/31 03:47

質問ページで画像の挿入できない為、文章のみでお話しします。
申し訳ありません。

全体を囲んでいる「p-service」クラスに対して背景色を指定し「position:relative」を記述し、
擬似要素で「transform: skewX(-45deg)」と記述し背景を白にしたものを実装したのですが、「right:0」の状態で変形させると画面の右側にはみ出てしまいます。

bodyに対して「overflow:hidden」を試しに記述してみましたが、他にデザイン上はみ出してるものがあり見えなくなってしまいます。

右側だけはみ出した擬似要素を非表示にすることはできないでしょうか?
ご教授いただければと思います。

HTML

1 <section class="p-service l-section"> 2 <div class="p-service_container"> 3 <div class="p-service_img"> 4 <img src="../img/common/image-services.jpg" alt="事業内容"> 5 </div> 6 <div class="p-service_cont"> 7 <h2 class="c-title_sub">SERVICES<span>事業内容</span></h2> 8 <p class="p-service_cont_subtitle">人々の生活基盤を<br>世界最高峰の技術で支える</p> 9 <p class="p-service_cont_text"> 10 私達のモットーは、 「社会基盤から世界をより良くする」こと。<br> 11 そのために最前線で国家規模のプロフェクトに参画することもあれば、<br> 12 世界各国の技術者、研究者と共に次世代の建設機材の研究開発事業も<br> 13 同時に行うことで、業界の進化の促進を担っています。 14 </p> 15 <a href="" class="c-button">事業内容を更に知る</a> 16 </div> 17 </div> 18 </section>

scss

1.p-service { 2 background:global.$gray; 3 height: 430px; 4 position: relative; 5 z-index: 10; 6 &::before { 7 //背景に変形させた白背景 8 content:''; 9 display: block; 10 position: absolute; 11 top:0; 12 right:0; 13 height: 100%; 14 width: 360px; 15 background: global.$white; 16 transform: skewX(-45deg); 17 z-index: -1; 18 } 19} 20 21 22.p-service_container { 23 display: flex; 24 padding-top: 40px; 25} 26 27.p-service_img { 28 img { 29 30 } 31} 32 33.p-service_cont { 34 margin-left: 48px; 35 &_subtitle { 36 margin-top: 20px; 37 @include global.fz(32,24); 38 @include global.lh(1.3); 39 } 40 41 &_text { 42 margin-top: 30px; 43 @include global.fz(16); 44 @include global.lh(2); 45 letter-spacing: 0.02em; 46 } 47} 48

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

recal

2021/12/31 18:56 編集

画像2MBまでなら挿入できませんか? 提示されたコードを使うだけで問題を再現出来る事を確認しましたか?(@includeは適用されなくても問題がない?) 前後要素がわからないのですが、clip-path: polygonみたいな変形の仕方だとNGですか? skewYにしてwidth:100%の形状等。
kogari

2022/01/01 04:20

画像サイズ関係なくブラウザ変えたら挿入できるようになりました。 clip-pathとwidthを調整したら実装できました! ありがとうございます!
recal

2022/01/01 09:22

おめでとうございます! 自己解決できたら、解決方法を投稿して自己解決を選んでもらえると、 後続の人が助かると思いますのでよろしくおねがいします。
guest

回答1

0

ベストアンサー

bodyではなく、直近の親の.p-serviceに対して、overflow: hiddenを指定すると良さそうです。

CSS

1.p-service { 2 background:global.$gray; 3 height: 430px; 4 position: relative; 5 z-index: 10; 6 overflow: hidden; // 追加 7 &::before { 8 .... 9 } 10}

投稿2022/01/10 01:41

monocode

総合スコア16

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問