Как наложить один div на другой div
надеюсь, кто-то может помочь, но мне нужна помощь с наложением одного человека div
над другим человеком div
.
мой код выглядит так:
<div class="navi"></div>
<div id="infoi">
<img src="info_icon2.png" height="20" width="32"/>
</div>
к сожалению, я не могу вложить div#infoi
или img
, внутри первого div.navi
.
это должно быть два отдельных div
s, как показано, но мне нужно знать, как я мог бы разместить div#infoi
на div.navi
и справа и по центру сверху div.navi
.
был бы признателен за любую помощь в достижении этого.
7 ответов
#container {
width: 100px;
height: 100px;
position: relative;
}
#navi,
#infoi {
width: 100%;
height: 100%;
position: absolute;
top: 0;
left: 0;
}
#infoi {
z-index: 10;
}
<div id="container">
<div id="navi">a</div>
<div id="infoi">
<img src="https://appharbor.com/assets/images/stackoverflow-logo.png" height="20" width="32" />b
</div>
</div>
Я бы предложил узнать о position: relative
и дочерние элементы с position: absolute
.
принятое решение отлично работает, но Имо не хватает объяснения, почему оно работает. Приведенный ниже пример сводится к основам и отделяет важный CSS от не относящегося к делу CSS-стиля. В качестве бонуса я также включил подробное объяснение того, как работает позиционирование CSS.
TLDR; если вам нужен только код, прокрутите вниз до Результат.
Проблема
есть 2 раздельные, брат, элементы и цель состоит в том, чтобы расположить 2-й элемент (с id
of infoi
) таким образом, он появляется в предыдущем элементе (тот, у которого class
of navi
). Структуру HTML изменить нельзя.
Предлагаемое Решение
для достижения желаемого результата мы собираемся переместить, или расположить, 2-й элемент, который мы будем называть #infoi
таким образом, он появляется в 1-м элементе, который мы будем называть .navi
. В частности, мы хотим #infoi
быть расположенным в верхний правый угол .navi
.
CSS позиция необходимые знания
CSS имеет несколько свойств для позиционирования элементов. По умолчанию, все элементы position: static
. Это означает, что элемент будет располагаться в соответствии с его порядком в структуре HTML, за несколькими исключениями.
другое position
значения relative
, absolute
и fixed
. Установив элемент position
в один из этих 3 значений теперь можно использовать комбинацию следующие 4 свойства для размещения элемента:
top
right
bottom
-
left
другими словами, установив position: absolute
, мы можем добавить top: 100px
чтобы расположить элемент 100px в верхней части страницы. И наоборот, если мы установим bottom: 100px
элемент будет расположен 100px от нижней части страницы.
вот где много новичков CSS заблудиться - position: absolute
есть рамки. В приведенном выше примере системой отсчета является body
элемент. position: absolute
С top: 100px
означает, что элемент позиционируется 100px
сверху body
элемент.
система координат позиции или контекст позиции могут быть изменены путем установки position
родительского элемента любое значение, кроме position: static
. То есть, мы можем создать новый контекст позицию предоставление родительского элемента:
position: absolute;
position: relative;
position: fixed;
например, если <div class="parent">
элемента position: relative
все дочерние элементы использовать <div class="parent">
как их позиция контекста. Если дочерний элемент был задан position: absolute
и top: 100px
, элемент будет расположен 100px от верхней части <div class="parent">
элемент, потому что <div class="parent">
теперь контекст позиции.
другой фактор осознавать это заказать стек - или как элементы укладываются в Z-направлении. Необходимо знать, что порядок стека элементов по умолчанию определяется обратным порядком в структуре HTML. Рассмотрим следующий пример:
<body>
<div>Bottom</div>
<div>Top</div>
</body>
в этом примере, если два <div>
элементы были расположены в том же месте на странице <div>Top</div>
элемент будет охватывать <div>Bottom</div>
элемент. С <div>Top</div>
после <div>Bottom</div>
в Структура HTML имеет более высокий порядок укладки.
div {
position: absolute;
width: 50%;
height: 50%;
}
#bottom {
top: 0;
left: 0;
background-color: blue;
}
#top {
top: 25%;
left: 25%;
background-color: red;
}
<div id="bottom">Bottom</div>
<div id="top">Top</div>
порядок укладки может быть изменен с помощью CSS с помощью z-index
или order
свойства.
мы можем игнорировать порядок укладки в этой проблеме, поскольку естественная структура HTML элементов означает элемент, на котором мы хотим появиться top
приходит после другого элемента.
Итак, вернемся к проблеме-мы будем использовать контекст позиции для ее решения вопрос.
Решение
как указано выше, наша цель-позиционировать #infoi
элемент, поэтому он появляется в пределах .navi
элемент. Для этого мы завернем .navi
и #infoi
элементы в новом элементе <div class="wrapper">
Итак, мы можем создать новый контекст позиции.
<div class="wrapper">
<div class="navi"></div>
<div id="infoi"></div>
</div>
затем создайте новый контекст позиции, дав .wrapper
a position: relative
.
.wrapper {
position: relative;
}
с этим новым контекстом позиции, мы можем расположить #infoi
внутри .wrapper
. Во-первых, дайте #infoi
a position: absolute
, что позволяет нам в положение #infoi
абсолютно .wrapper
.
затем добавить top: 0
и right: 0
в положение #infoi
элемент в правом верхнем углу. Помните, потому что #infoi
элемент, используя .wrapper
в качестве контекста позиции он будет находиться в правом верхнем углу .wrapper
элемент.
#infoi {
position: absolute;
top: 0;
right: 0;
}
, потому что .wrapper
- это просто контейнер для .navi
позиционирование #infoi
в правом верхнем углу .wrapper
дает эффект расположения в правом верхнем углу .navi
.
и вот оно,#infoi
теперь, кажется, находится в правом верхнем углу .navi
.
Результат
приведенный ниже пример сводится к основам и содержит некоторые минимальные стили.
/*
* position: relative gives a new position context
*/
.wrapper {
position: relative;
}
/*
* The .navi properties are for styling only
* These properties can be changed or removed
*/
.navi {
background-color: #eaeaea;
height: 40px;
}
/*
* Position the #infoi element in the top-right
* of the .wrapper element
*/
#infoi {
position: absolute;
top: 0;
right: 0;
/*
* Styling only, the below can be changed or removed
* depending on your use case
*/
height: 20px;
padding: 10px 10px;
}
<div class="wrapper">
<div class="navi"></div>
<div id="infoi">
<img src="http://via.placeholder.com/32x20/000000/ffffff?text=?" height="20" width="32"/>
</div>
</div>
Альтернативное (Без Обертки) Решение
в случае, если мы не можем редактировать HTML, то есть мы не удается добавить элемент обертки, мы все еще можем достичь желаемого эффекта.
вместо position: absolute
на #infoi
элемент, мы будем использовать position: relative
. Это позволяет нам переместить #infoi
элемент из его позиции по умолчанию ниже .navi
элемент. С position: relative
мы можем использовать отрицательные top
значение, чтобы переместить его из позиции по умолчанию, и left
стоимостью 100%
минус несколько пикселей, используя left: calc(100% - 52px)
, чтобы поместить его рядом с правой стороны.
/*
* The .navi properties are for styling only
* These properties can be changed or removed
*/
.navi {
background-color: #eaeaea;
height: 40px;
width: 100%;
}
/*
* Position the #infoi element in the top-right
* of the .wrapper element
*/
#infoi {
position: relative;
display: inline-block;
top: -40px;
left: calc(100% - 52px);
/*
* Styling only, the below can be changed or removed
* depending on your use case
*/
height: 20px;
padding: 10px 10px;
}
<div class="navi"></div>
<div id="infoi">
<img src="http://via.placeholder.com/32x20/000000/ffffff?text=?" height="20" width="32"/>
</div>
С помощью div
стиль z-index:1;
и position: absolute;
вы можете наложить свой div
на любой другой div
.
z-index
определяет порядок, в котором divs 'stack'. Div с более высоким z-index
появится перед div с более низким z-index
. Обратите внимание, что это свойство работает только с позиционированными элементами.
Это то, что вам нужно:
function showFrontLayer() {
document.getElementById('bg_mask').style.visibility='visible';
document.getElementById('frontlayer').style.visibility='visible';
}
function hideFrontLayer() {
document.getElementById('bg_mask').style.visibility='hidden';
document.getElementById('frontlayer').style.visibility='hidden';
}
#bg_mask {
position: absolute;
top: 0;
right: 0; bottom: 0;
left: 0;
margin: auto;
margin-top: 0px;
width: 981px;
height: 610px;
background : url("img_dot_white.jpg") center;
z-index: 0;
visibility: hidden;
}
#frontlayer {
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
margin: 70px 140px 175px 140px;
padding : 30px;
width: 700px;
height: 400px;
background-color: orange;
visibility: hidden;
border: 1px solid black;
z-index: 1;
}
</style>
<html>
<head>
<META HTTP-EQUIV="EXPIRES" CONTENT="-1" />
</head>
<body>
<form action="test.html">
<div id="baselayer">
<input type="text" value="testing text"/>
<input type="button" value="Show front layer" onclick="showFrontLayer();"/> Click 'Show front layer' button<br/><br/><br/>
Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text
Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text
Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing textsting text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text Testing text
<div id="bg_mask">
<div id="frontlayer"><br/><br/>
Now try to click on "Show front layer" button or the text box. It is not active.<br/><br/><br/>
Use position: absolute to get the one div on top of another div.<br/><br/><br/>
The bg_mask div is between baselayer and front layer.<br/><br/><br/>
In bg_mask, img_dot_white.jpg(1 pixel in width and height) is used as background image to avoid IE browser transparency issue;<br/><br/><br/>
<input type="button" value="Hide front layer" onclick="hideFrontLayer();"/>
</div>
</div>
</div>
</form>
</body>
</html>
здесь следует простое решение 100% на основе CSS. "Секрет" заключается в использовании display: inline-block
в элементе оболочки. The vertical-align: bottom
в изображении хак, чтобы преодолеть 4px заполнение, что некоторые браузеры добавляют после элемента.
советы: если элемент перед оболочкой встроен, они могут оказаться вложенными. В этом случае вы можете "обернуть обертку" внутри контейнера с помощью display: block
- обычно хороший и старый div
.
.wrapper {
display: inline-block;
position: relative;
}
.hover {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-color: rgba(0, 188, 212, 0);
transition: background-color 0.5s;
}
.hover:hover {
background-color: rgba(0, 188, 212, 0.8);
// You can tweak with other background properties too (ie: background-image)...
}
img {
vertical-align: bottom;
}
<div class="wrapper">
<div class="hover"></div>
<img src="http://placehold.it/450x250" />
</div>
Я не очень кодер и не эксперт в CSS, но я все еще использую вашу идею в своих веб-проектах. Я тоже пробовал разные разрешения:
#wrapper {
margin: 0 auto;
width: 901px;
height: 100%;
background-color: #f7f7f7;
background-image: url(images/wrapperback.gif);
color: #000;
}
#header {
float: left;
width: 100.00%;
height: 122px;
background-color: #00314e;
background-image: url(images/header.jpg);
color: #fff;
}
#menu {
float: left;
padding-top: 20px;
margin-left: 495px;
width: 390px;
color: #f1f1f1;
}
<div id="wrapper">
<div id="header">
<div id="menu">
menu will go here
</div>
</div>
</div>
конечно, вокруг них обоих будет обертка. Вы можете управлять расположением меню div, которое будет отображаться в заголовке div с левыми полями и верхними позициями. Вы также можете установить меню div, чтобы плавать вправо, если хотите. Надеюсь, это поможет.
вот простой пример, чтобы принести эффект наложения с загрузкой значка над другим div.
<style>
#overlay {
position: absolute;
width: 100%;
height: 100%;
background: black url('icons/loading.gif') center center no-repeat; /* Make sure the path and a fine named 'loading.gif' is there*/
background-size: 50px;
z-index: 1;
opacity: .6;
}
.wraper{
position: relative;
width:400px; /* Just for testing, remove width and height if you have content inside this div*/
height:500px; /*Remove this if you have content inside*/
}
</style>
<h2>The overlay tester</h2>
<div class="wraper">
<div id="overlay"></div>
<h3>Apply the overlay over this div</h3>
</div>
попробуй здесь http://jsbin.com/fotozolucu/edit?html, css, выход