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

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

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

SafariはAppleのウェブブラウザであり、Mac OS XとiOSのデフォルトのブラウザです。

HTML

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

CSS

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

Q&A

解決済

1回答

3387閲覧

safariでの擬似要素とtransformの意図しない挙動

vabo

総合スコア171

Safari

SafariはAppleのウェブブラウザであり、Mac OS XとiOSのデフォルトのブラウザです。

HTML

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

CSS

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

0グッド

0クリップ

投稿2021/08/20 03:32

編集2021/08/20 05:22

ページトップに戻るボタンをhtmlとcssで制作しているのですが、safariでページを表示した際にのみ、擬似要素とtransformに意図しない挙動が発生してしまいます。
divをフッターの部分にposition:absoluteで配置しており、ホバーするとtransitionで少し上に浮くアニメーションをつけているのですが、safariでページを表示した際に、擬似要素の矢印のborder-topの部分が表示されていない(擬似要素のwidthが反映されていない?)状態で表示されてしまい、ホバーすると、矢印が正しく表示されて全体が左に寄ってから、上に浮くアニメーションが発火するような状態になっています。
ページが表示されてから一度ホバーするとその後は正常な状態で表示され、transitionも正しく動きます(更新するとまた最初の表示に戻ってしまいます)
chromeなど他のブラウザでは最初から正常に表示されています。
原因がつかめず詰まっております。。お力添えいただけると助かります、よろしくお願いいたします。
イメージ説明

html

1<footer> 2 <div id="page-top"> 3 <a href="#">PAGETOP</a> 4 </div> 5</footer>

scss

1footer{ 2 background: #ff5c6d; 3 color: white; 4 padding: 20% 5% 2% 25%; 5 position: relative; 6} 7 8#page-top{ 9 cursor: pointer; 10 display: flex; 11 align-items: flex-end; 12 right: 30px; 13 transition-duration: 0.5s; 14 transition-property: transform; 15 position: absolute; 16 top: 12px; 17 &:hover{ 18 transform: translate(0, -10px); 19 } 20 a{ 21 writing-mode: vertical-lr; 22 font-weight: bold; 23 color: white; 24 text-decoration: none; 25 } 26 &::before{ 27 content: ""; 28 width: 8px; 29 height: 94px; 30 border-top: 1px solid white; 31 border-left: 1px solid white; 32 transform: skew(0deg, 45deg); 33 } 34}

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

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

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

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

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

guest

回答1

0

自己解決

id#page-topにwidthを指定したところ正常に表示されるようになりました。
しかし何故一度ホバーすると元に戻ったのでしょうか。。この挙動がよくわからないので、引き続き調べてみようと思います。

投稿2021/08/24 07:31

編集2021/08/24 07:32
vabo

総合スコア171

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問