#javascript #html #css #hover #mousehover
#javascript #HTML #css #наведите #наведение курсора мыши
Вопрос:
У меня есть несколько блоков подряд, у каждого блока есть пользовательский всплывающий div. Если пользователь наводит курсор на последний div или предпоследний div в строке, всплывающее окно выходит за пределы ширины окна. Я хочу, чтобы, если с правой стороны нет места для всплывающего окна, тогда класс tile-box изменился на tile-box1. Заранее спасибо! Ниже приведен URL-адрес code pen для ссылки, и я также прикрепляю изображение.
.content {
display: flex;
flex-wrap: wrap;
}
.box {
width: 150px;
height: 100px;
position: relative;
border: 1px solid #ddd;
}
.box:hover .tile-box {
display: block;
;
}
.tile-box {
display: none;
position: absolute !important;
z-index: 9;
top: -6px;
left: 169px;
width: 220px;
height: auto;
/* padding: 15px; */
margin-top: 15px;
position: relative;
background: #fff;
border-radius: 8px;
box-shadow: 0 0 14px 0 rgba(0, 0, 0, 0.06);
border: solid 1px #e8e8e8;
/* -webkit-transition: all 0.5s ease;
-moz-transition: all 0.5s ease;
-o-transition: all 0.5s ease;
transition: all 0.5s ease; */
}
.tile-box {
padding: 15px !important;
/* display: block !important; */
}
.tile-box::after {
content: "";
position: absolute;
width: 0;
height: 0;
top: 32px;
left: 0px;
-webkit-box-sizing: border-box;
box-sizing: border-box;
border-width: 8px;
border-style: solid;
border-color: transparent transparent white white;
-webkit-transform-origin: 0 0;
-webkit-transform: rotate(45deg);
-ms-transform-origin: 0 0;
transform-origin: 0 0;
-ms-transform: rotate(45deg);
transform: rotate(45deg);
-webkit-box-shadow: -3px 2px 2px rgba(0, 0, 0, 0.05);
box-shadow: -3px 2px 2px rgba(0, 0, 0, 0.05);
}
.tile-box1{
display:block;
}
<div class="content">
<div class="box">
<h1>box 1</h1>
<div class="tile-box">
<p>lorem ipsum dolor</p>
</div>
</div>
<div class="box">
<h1>box 2</h1>
<div class="tile-box">
<p>lorem ipsum dolor</p>
</div>
</div>
<div class="box">
<h1>box 3</h1>
<div class="tile-box">
<p>lorem ipsum dolor</p>
</div>
</div>
<div class="box">
<h1>box 4</h1>
<div class="tile-box">
<p>lorem ipsum dolor</p>
</div>
</div>
</div>
Url-адрес Codepen: (https://codepen.io/uibeast/pen/yLJgJra )
Комментарии:
1. думаю, вам понадобится js для вычисления, достаточно ли у вас места для наведения
2. Пожалуйста, поделитесь примером кода, если у вас есть. Заранее спасибо.
Ответ №1:
Вот немного Javascript, который должен помочь определить, когда плитка выходит за пределы. На данный момент я включил только фиктивный журнал консоли, вы должны иметь возможность переключать имена классов или что-то в этом роде вместо журнала консоли.
По сути, то, что делает код, — это получает x-координату самой правой части плитки и сравнивает ее с window.innerHeight
. Если первое больше, то плитка выходит за пределы правой части окна.
$(".box").on("mouseenter", function() {
var tile = $(this).find(".tile-box")[0];
var rect = tile.getBoundingClientRect();
//if right of tile is beyond viewport
if(rect.right > window.innerWidth) {
//dummy console log for demo
console.log("doesn't fit!");
//switch class of tile or something
}
})
ДЕМОНСТРАЦИЯ:
$(".box").on("mouseenter", function() {
var tile = $(this).find(".tile-box")[0];
var rect = tile.getBoundingClientRect();
//if right of tile is beyond viewport
if(rect.right > window.innerWidth) {
//dummy console log for demo
console.log("doesn't fit!");
//switch class of tile or something
}
})
.content {
display: flex;
flex-wrap: wrap;
}
.box {
width: 150px;
height: 100px;
position: relative;
border: 1px solid #ddd;
}
.box:hover .tile-box {
display: block;
;
}
.tile-box {
display: none;
position: absolute !important;
z-index: 9;
top: -6px;
left: 169px;
width: 220px;
height: auto;
/* padding: 15px; */
margin-top: 15px;
position: relative;
background: #fff;
border-radius: 8px;
box-shadow: 0 0 14px 0 rgba(0, 0, 0, 0.06);
border: solid 1px #e8e8e8;
/* -webkit-transition: all 0.5s ease;
-moz-transition: all 0.5s ease;
-o-transition: all 0.5s ease;
transition: all 0.5s ease; */
}
.tile-box {
padding: 15px !important;
/* display: block !important; */
}
.tile-box::after {
content: "";
position: absolute;
width: 0;
height: 0;
top: 32px;
left: 0px;
-webkit-box-sizing: border-box;
box-sizing: border-box;
border-width: 8px;
border-style: solid;
border-color: transparent transparent white white;
-webkit-transform-origin: 0 0;
-webkit-transform: rotate(45deg);
-ms-transform-origin: 0 0;
transform-origin: 0 0;
-ms-transform: rotate(45deg);
transform: rotate(45deg);
-webkit-box-shadow: -3px 2px 2px rgba(0, 0, 0, 0.05);
box-shadow: -3px 2px 2px rgba(0, 0, 0, 0.05);
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="content">
<div class="box">
<h1>box 1</h1>
<div class="tile-box">
<p>lorem ipsum dolor</p>
</div>
</div>
<div class="box">
<h1>box 2</h1>
<div class="tile-box">
<p>lorem ipsum dolor</p>
</div>
</div>
<div class="box">
<h1>box 3</h1>
<div class="tile-box">
<p>lorem ipsum dolor</p>
</div>
</div>
<div class="box">
<h1>box 4</h1>
<div class="tile-box">
<p>lorem ipsum dolor</p>
</div>
</div>
</div>
Комментарии:
1. Я добавил div с именем tile-box1 и написал код, чтобы показать div tile-box1 и скрыть tile-box вместо console.log. После наведения курсора на последний div поле тайла скрылось и отображается поле тайла1. Из-за этого плитка-бокс не отображается ни для одного из div. Я делаю что-то не так?