positionの指定によって画像が表示されたり表示されなかったり表示されるものの回転しなかったり、それぞれの理由がわからないので教えていただきたいです。
JavaScriptで画像が弧を描くという内容です。
javascript
1 const character = document.querySelector('.character'); 2 3 let degree = 0; 4 5 loop(); 6 7 function loop() { 8 const rotation = (degree * Math.PI) / 180; 9 const targetX = window.innerWidth / 2 + 100 * Math.cos(rotation) - 50; 10 const targetY = window.innerHeight / 2 + 100 * Math.sin(rotation) - 50; 11 12 character.style.left = `${targetX}px`; 13 character.style.top = `${targetY}px`; 14 15 degree += 1; 16 17 requestAnimationFrame(loop); 18 }
css
1.character { 2 background-image: url('../image/character.png'); 3 background-size: 100px 100px; 4 width: 100px; 5 height: 100px; 6 position:absolute; 7 top: 0; 8 left: 0; 9}
このとき、css の position の行を削除すると画像が表示されるものの回転しません。プロパティを absolute にしても relativeにしても全く同じように表示されます。absolute は絶対位置で relative は相対位置だったと思うのですがなぜどちらも同じ位置になるのかがわかりません。
1)position が static の場合に画像が表示されるものの弧を描かない理由はなんでしょうか?
2)position が absolute, relative のそれぞれで全く同じ位置に表示されるのはなぜでしょうか?
アドバイスよろしくお願いいたします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2022/07/13 23:15