Проблема с наведением курсора на div, горизонтальная прокрутка идет на последнем div

#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. Я делаю что-то не так?