Jump to content
  • 0

Позиционирование слоев в разных браузерах


Safronik
 Share

Question

Следующий код в браузере Chrome и Operа отображается по разному:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css">
#id {
position: absolute;
margin-top: 10%;
margin-left: 10%;
width: 100px;
height: 10%;
background-color: black;
}
#id2 {
position: absolute;
margin-top: 20%;
margin-left: 10%;
width: 100px;
height: 10%;
background-color: green;
}
</style>
</head>
<body>
<div id="id">First layer</div>
<div id="id2">Second layer</div>
</body>
</html>

Проблема в том что Opera почему-то делает не большой промежуток между слоями. Много чего перепробовал. Если задавать отступы в пикселях и.т.п., отображается корректно. Может виноват доктайп?

Кто сталкивался, подскажите...

Edited by Safronik
Link to comment
Share on other sites

6 answers to this question

Recommended Posts

  • 0

извиняюсь, выложил не совсем правильный код. исправил.

хм. не совсем понял, то есть совсем не понял... смысл в том что бы эти два слоя располагались друг под другом, без зазоров. хром выводит все замечательно. но опера на сколько я понял использует разные %(от body) для высоты слоя и отступа...

Вот что показывает опера:

1.JPG

Edited by Safronik
Link to comment
Share on other sites

  • 0

#id {
position: absolute;
top: 10%;
/*margin:10% 0 0 10%;*/
margin:0;
margin-left:10%;
width: 10%;
height: 10%;
background: black;
}
#id2 {
position: absolute;
top: 20%;
/*margin:20% 0 0 10%;*/
margin:0;
margin-left:10%;
width: 100px;
height: 10%;
background: green;
}
html,body{
height: 100%;
margin:0;
padding:0;
}

так показывает получше, но в FF нету пиксельного промежутка,

а в хроме и опере есть.

А почему это должно зависеть от ширины? Высота еще понятно..

Где об этом можно почитать (keyword если можно)?

С уважением, Олег.

Link to comment
Share on other sites

  • 0
Если вы используете position: absolute, то не надо элементы позиционировать с помощью полей. Сделайте так:

#id {
position: absolute;
top: 10%;
/*margin:10% 0 0 10%;*/
margin:0;
margin-left:10%;
width: 10%;
height: 10%;
background: black;
}
#id2 {
position: absolute;
top: 20%;
/*margin:20% 0 0 10%;*/
margin:0;
margin-left:10%;
width: 100px;
height: 10%;
background: green;
}
html,body{
height: 100%;
margin:0;
padding:0;
}

так показывает получше, но в FF нету пиксельного промежутка,

а в хроме и опере есть.

А почему это должно зависеть от ширины? Высота еще понятно..

Где об этом можно почитать (keyword если можно)?

С уважением, Олег.

Пиксельный промежуток может появиться в каком угодно браузере, он появляется из-за разных размеров окна, потому что проценты не могут быть выражены в целых пикселях.

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

 Share

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue. See more about our Guidelines and Privacy Policy