【CSS】「fixedで固定されない⁉」を速攻解決する方法!

この記事は約2分で読めます。
広告

固定させたい要素「header」とかロゴやドロワーメニューに「position:fixed」したのに固定されない時の解決方法のご紹介です。

親要素に「transform: translate3d(0,0,0)」を指定してる!

親要素に「transform: translate3d(0,0,0)」を指定している場合「fixed」が効かなくなる現象があります。「transform: translate3d(0,0,0)」はアニメーションを滑らかにする為に書いていて、実際僕も固定したはずの「header」が固定されず、「absolute」を指定していたかのような挙動をしていて「?」となりました。
解決方法は、親要素の「transform: translate3d(0,0,0)」を削除して、固定したい要素以外に「transform: translate3d(0,0,0)」を付ければ解決!
例えば、「header」以外に「transform: translate3d(0,0,0)」を指定する場合。

body >:not(header) {transform: translate3d(0,0,0);}
// 「header」以外に複数を除外する場合「,」区切りで指定
body >:not(header, .demo, main, footer) {transform: translate3d(0,0,0);}
エンデ・バタローをフォローする
CSSサイト制作

埼玉県北本市に越してきて2年と少しになります。以前は東京都の京王線沿線に、その前は神戸の三宮、さらにその前は名古屋の八事霊園近くに住んでいました。

怖い話が大好きで、ネット怪談、ホラー小説、心霊Youtuber(オウマガドキch、ゾゾゾ)を寝る前のお供にしてます。

フロントエンドエンジニアとして9年目のキャリアを積んでおり、figma、Illustrator、Photoshop、WordPress、HTML、CSS(scss)、JavaScript(jQuery)、PHPなど使って日々仕事をしています。

仕事で検索する手間を省くためフロントエンド技術に関するブログを書いています。

エンデ・バタローをフォローする
広告
初めてのブログ

コメント

タイトルとURLをコピーしました