私はウェブサイトを作っています、そして、水平スクロールバーは示します。もちろん、私は使用することができoverflow-x
、それは私のすべての問題を解決しますが、私は問題の原因を知りたいです。スクロールバーが表示される理由を誰かに教えてもらえますか?これが私のCSSです:
body {
background-image: url("rain.jpg");
background-repeat: no-repeat;
background-size: 100% 800px;
}
#header {
width: 83%;
height: 70px;
background-color: blue;
border: cyan solid 3px;
border-radius:20px;
position: relative;
top: 20px;
margin: auto;
}
p {
font-size:30px;
font-weight: bold;
color: yellow;
position: relative;
right: -450px;
top: -8px;
}
#container {
position: relative;
width: 83%;
height: 1000px;
top: 50px;
margin: auto;
background-color: blue;
}
.img {
height: 150px;
width: 225px;
padding: 0px;
padding-top: 30px;
cursor: pointer;
opacity: 1;
}
.click {
height: 400px;
width: 600px;
position: relative;
right: -200px;
cursor: pointer;
}
li {
display: inline-block;
}
<p>
要素が比較的配置され、right: -450px
。で右にシフトされていることに注意してください。
ではposition: relative
要素の元のスペースが確保されています。したがって、要素を右に450ピクセルシフトしている間、レイアウト内の元のスペースはそのまま維持され、ドキュメントは水平方向に長くなります。それがスクロールバーの理由です。
right: -450px
ルールを削除または調整して、違いを確認します。
また、単に対比のために、配置を切り替えるrelative
とabsolute
、ドキュメントフローから要素が削除され、元のスペースが削除されます。
この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。
侵害の場合は、連絡してください[email protected]
コメントを追加