Я намагаюся зробити напівпрозорий div, який охоплює весь екран. Я спробував це:
#dimScreen
{
width: 100%;
height: 100%;
background:rgba(255,255,255,0.5);
}
Але це не охоплює весь екран, воно охоплює лише область у div.
Я намагаюся зробити напівпрозорий div, який охоплює весь екран. Я спробував це:
#dimScreen
{
width: 100%;
height: 100%;
background:rgba(255,255,255,0.5);
}
Але це не охоплює весь екран, воно охоплює лише область у div.
Відповіді:
Додати 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. Чим більше число, тим більше рівнів воно охоплює.
top: 0; left: 0;
Вам потрібно встановити батьківський елемент 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%;}
position:relative. Це не спрацює. Запропонуйте position:fixedзамість цього.
Це зробить трюк!
div {
height: 100vh;
width: 100vw;
}
Використовуйте 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/
Спробуйте це
#dimScreen {
width: 100%;
height: 100%;
background:rgba(255,255,255,0.5);
position: fixed;
top: 0;
left: 0;
}
Застосуйте 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;
}
Встановіть 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/
будь ласка, спробуйте встановити поле та відступ до 0 на тілі.
<body style="margin: 0 0 0 0; padding: 0 0 0 0;">
position: absolute; top: 0; left: 0;