Дозвольте div охоплювати всю сторінку, а не область у контейнері


90

Я намагаюся зробити напівпрозорий div, який охоплює весь екран. Я спробував це:

#dimScreen
{
    width: 100%;
    height: 100%;
    background:rgba(255,255,255,0.5);
}

Але це не охоплює весь екран, воно охоплює лише область у div.


4
Додатиposition: absolute; top: 0; left: 0;
Сергій Паращів

Чи є оновлення для CSS3 або будь-які розширення, які вони мають сьогодні?
Вільям Ентрікен

Відповіді:


173

Додати position:fixed. Потім кришка фіксується на всьому екрані, також коли ви прокручуєте.
І додайте, можливо, також, margin: 0; padding:0;щоб у нього не було місця навколо обкладинки.

#dimScreen
{
    position:fixed;
    padding:0;
    margin:0;

    top:0;
    left:0;

    width: 100%;
    height: 100%;
    background:rgba(255,255,255,0.5);
}

І якщо він не повинен фіксуватися на екрані фіксовано, використовуйте position:absolute;

CSS Tricks також має цікаву статтю про повноекранну властивість.

Редагувати:
Щойно натрапив на цю відповідь, тому я хотів додати кілька додаткових речей.
Як і Деніел Аллен Ленґдон, згаданий у коментарі, додайте top:0; left:0;точно, обкладинка тримається вгорі та ліворуч на екрані.

Якщо деякі елементи знаходяться у верхній частині обкладинки (щоб вони не охоплювали все), додайте z-index. Чим більше число, тим більше рівнів воно охоплює.


1
З мого досвіду мені теж знадобиласяtop: 0; left: 0;
Вівіан Рівер

Я завжди боровся з цим, але використання фіксованого положення працювало набагато краще. Дякую
BrianLegg

2
Очевидно, є зачіпка: якщо елемент position: fixed має предка з перетворенням css, то він буде фіксований щодо цього предка замість області перегляду. developer.mozilla.org/en-US/docs/Web/CSS/position#Values
mpoisot

18

Вам потрібно встановити батьківський елемент 100%, а

html, body {
    height: 100%;
}

Демонстрація (Зміненоbackgroundдля демонстрації)


Крім того, коли ви хочете охопити весь екран, здається, що хочете dim, тому в цьому випадку вам потрібно використовуватиposition: fixed;

#dimScreen {
    width: 100%;
    height: 100%;
    background:rgba(255,255,255,0.5); 
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100; /* Just to keep it at the very top */
}

Якщо це так, то вам не потрібно html, body {height: 100%;}

Демо 2


2
Можливо, хтось із батьків має position:relative. Це не спрацює. Запропонуйте position:fixedзамість цього.
Мухаммед Талха Акбар

@MuhammadTalhaAkbar О, розумію, вже dt відповів, що, думаю, мені слід видалити свою відповідь
містер

Краще за інших, якщо ви просто трохи його зміните.
Мухаммед Талха Акбар


7

Використовуйте position:fixedцей спосіб, щоб ваш div постійно залишався на всій видимій області.

дайте своєму div клас overlayі створіть таке правило у своєму CSS

.overlay{
    opacity:0.8;
    background-color:#ccc;
    position:fixed;
    width:100%;
    height:100%;
    top:0px;
    left:0px;
    z-index:1000;
}

Демонстрація: http://www.jsfiddle.net/TtL7R/1/




1

Застосуйте css-reset, щоб скинути всі поля та відступи, подібні до цього

/* http://meyerweb.com/eric/tools/css/reset/ 

v2.0 | 20110126 Ліцензія: немає (загальнодоступне) * /

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font-size: 100%;
font: inherit;
vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
display: block;
}
body {
line-height: 1;
}
ol, ul {
list-style: none;
}
blockquote, q {
quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
content: '';
content: none;
}
table {
border-collapse: collapse;
border-spacing: 0;
}

Ви можете використовувати різні css-скидання, як вам потрібно, звичайно і використовувати в css

 html
 {
  margin: 0px;
 padding: 0px;
 }

body
{
margin: 0px;
padding: 0px;
}

2
Як це актуально?
akauppi

0

Встановіть HTML і тіла теги heightдля 100%і видалити край навколо тіла:

html, body {
    height: 100%;
    margin: 0px; /* Remove the margin around the body */
}

Тепер встановіть positionдля вашого div fixed:

#dimScreen
{
    width: 100%;
    height: 100%;
    background:rgba(255,255,255,0.5);

    position: fixed;
    top: 0px;
    left: 0px;

    z-index: 1000; /* Now the div will be on top */
}

Демонстрація: http://jsfiddle.net/F3LHW/


Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.