Javascript 将鼠标悬停在内容/正文上时,使弹出式悬停内容保持打开状态

Javascript 将鼠标悬停在内容/正文上时,使弹出式悬停内容保持打开状态,javascript,html,css,ruby,ruby-on-rails-5,Javascript,Html,Css,Ruby,Ruby On Rails 5,我正在尝试使用javascript和css创建自定义悬停 一切都很好,我可以切换类来显示和隐藏弹出/悬停气泡。 (弹出式正文) 但是,当光标悬停在气泡上时,我希望气泡也保持打开状态。 (弹出式正文) 这会在离开弹出链接后立即关闭,如果我渲染弹出体中的任何链接,则悬停操作将无效。请帮忙 HTML/ERB <div class="popup-container"> <span class="popup-link">Partner disclosure</span&g

我正在尝试使用javascript和css创建自定义悬停

一切都很好,我可以切换类来显示和隐藏弹出/悬停气泡。 (弹出式正文)

但是,当光标悬停在气泡上时,我希望气泡也保持打开状态。 (弹出式正文)

这会在离开弹出链接后立即关闭,如果我渲染弹出体中的任何链接,则悬停操作将无效。请帮忙

HTML/ERB

<div class="popup-container">
  <span class="popup-link">Partner disclosure</span>
  <span class="popup-body popup-bottom">
    <h3>Partner relationships</h3>

    <p>stuffs in popup body</p>
  </span>
</div>
CSS


我可能误解了你的意思,但如果你只是想让身体在其位置离开时离开,为什么不将mouseexit函数添加到该元素中呢?下面是我指的,在一个片段中

$(document).on('mouseenter click','popup link',function(){
var popupContent=$(this).parent('.popup container').find('.popup body');
addClass('show-popup');
})
$(document).on('mouseleave','.popup body',function()){
$(“.popup body”).removeClass('show-popup');
})
$(文档)。在('点击触摸')上,功能(e){
如果(!e.target.classList.contains(“.popup body”)){
$(“.popup body”).removeClass('show-popup');
}
});
.popup容器{
位置:相对位置;
显示:内联块;
背景:无;
光标:指针;
}
.popup容器.popup主体{
可见性:隐藏;
位置:绝对位置;
宽度:676px;
背景色:$白色;
颜色:#000;
文本对齐:左对齐;
填充:30px;
z指数:1;
不透明度:0;
过渡:不透明度0.3s;
-webkit盒阴影:0px 2px 4px 0 rgba(0,0,0,0.5);
-moz盒阴影:0px 2px 4px 0 rgba(0,0,0,0.5);
盒影:0 2px4p0 rgba(0,0,0,0.5);
}
.popup容器。显示弹出窗口{
能见度:可见;
不透明度:1;
@包括susy断点(0$breakpoint,8){
宽度:350px;
}
}
.弹出底部{
最高:135%;
左:50%;
左边距:-60px;
}

合伙人披露
伙伴关系
弹出式正文中的内容


我可能误解了您的意思,但是如果您只是希望主体在其位置离开时离开,为什么不将mouseexit函数添加到该元素中呢?下面是我指的,在一个片段中

$(document).on('mouseenter click','popup link',function(){
var popupContent=$(this).parent('.popup container').find('.popup body');
addClass('show-popup');
})
$(document).on('mouseleave','.popup body',function()){
$(“.popup body”).removeClass('show-popup');
})
$(文档)。在('点击触摸')上,功能(e){
如果(!e.target.classList.contains(“.popup body”)){
$(“.popup body”).removeClass('show-popup');
}
});
.popup容器{
位置:相对位置;
显示:内联块;
背景:无;
光标:指针;
}
.popup容器.popup主体{
可见性:隐藏;
位置:绝对位置;
宽度:676px;
背景色:$白色;
颜色:#000;
文本对齐:左对齐;
填充:30px;
z指数:1;
不透明度:0;
过渡:不透明度0.3s;
-webkit盒阴影:0px 2px 4px 0 rgba(0,0,0,0.5);
-moz盒阴影:0px 2px 4px 0 rgba(0,0,0,0.5);
盒影:0 2px4p0 rgba(0,0,0,0.5);
}
.popup容器。显示弹出窗口{
能见度:可见;
不透明度:1;
@包括susy断点(0$breakpoint,8){
宽度:350px;
}
}
.弹出底部{
最高:135%;
左:50%;
左边距:-60px;
}

合伙人披露
伙伴关系
弹出式正文中的内容


这取决于你的意思。从技术上讲,你会发射一个穿越身体的mouseexit事件。你可以设置一个超时。预期用例是什么?我原本以为是老鼠的尸体一直留到老鼠离开尸体。你希望它在其他情况下也离开吗?我现在也在链接元素上附加了一个点击。您还可以检测是否在主体上单击并删除类似的类。您必须将单击侦听器附加到主体上。这就是事情变得有点棘手的地方。我会做一些研究(这是永远的),然后再给你回复。:)看看我的代码,看看它是否适合你。我不确定这是否是处理per-see的最佳实践,但它似乎确实按照您的预期工作。我可能会让代码更d.R.Y.(不要重复你自己)。您可以缓存变量,而不是每次都解析DOM来查找它们<代码>var popubody=$('.popup body)请告诉我是否有办法测试它。我几乎可以肯定,点击会转化为浏览器上的触摸事件。我看看我能做些什么这取决于你的意思。从技术上讲,你会发射一个穿越身体的mouseexit事件。你可以设置一个超时。预期用例是什么?我原本以为是老鼠的尸体一直留到老鼠离开尸体。你希望它在其他情况下也离开吗?我现在也在链接元素上附加了一个点击。您还可以检测是否在主体上单击并删除类似的类。您必须将单击侦听器附加到主体上。这就是事情变得有点棘手的地方。我会做一些研究(这是永远的),然后再给你回复。:)看看我的代码,看看它是否适合你。我不确定这是否是处理per-see的最佳实践,但它似乎确实按照您的预期工作。我可能会让代码更d.R.Y.(不要重复你自己)。您可以缓存变量,而不是每次都解析DOM来查找它们<代码>var popubody=$('.popup body)请告诉我是否有办法测试它。我几乎可以肯定,点击会转化为浏览器上的触摸事件。我看看我能做些什么
$(document).on('mouseleave click', '.popup-body', function() {
   $(".popup-body").removeClass('show-popup');
})

### if mobile device
if (/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent) ) {

  $(document).on('click', '.popup-link', function() {
     var popupContent = $(this).parent('.popup-container').find('.popup-body');
     if (!popupContent.hasClass('show-popup')) {
       popupContent.addClass('show-popup');
     } else {
       popupContent.removeClass('show-popup');
     }
  })

  $(document).on('touchstart', '.page-content', function(e) {
    if ( !e.target.classList.contains(".popup-body") ) {
      $(".popup-body").removeClass('show-popup');
    }
  });

} else { ###desktop

  $(document).on('mouseenter', '.popup-link', function() {
      var popupContent = $(this).parent('.popup-container').find('.popup-body');
      popupContent.addClass('show-popup');
  })

  $(document).on('click', '.page-content', function(e) {
    if ( !e.target.classList.contains(".popup-body") ) {
      $(".popup-body").removeClass('show-popup');
    }
  });
}
.popup-container {
  position: relative;
  display: inline-block;
  background: none;
  cursor: pointer;
}

.popup-container .popup-body {
  visibility: hidden;
  position: absolute;
  width: 676px;
  background-color: $color-white;
  color: #000;
  text-align: left;
  padding: 30px;
  z-index: 1;
  opacity: 0;
  transition: opacity 0.3s;
  -webkit-box-shadow: 0px 2px 4px 0 rgba(0, 0, 0, 0.5);
  -moz-box-shadow: 0px 2px 4px 0 rgba(0, 0, 0, 0.5);
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.5);
}

.popup-container .show-popup {
  visibility: visible;
  opacity: 1;
  @include susy-breakpoint(0 $breakpoint-tablet-landscape, 8) {
    width: 350px;
  }
}

.popup-bottom {
  top: 135%;
  left: 50%;
  margin-left: -60px;
}

.popup-bottom::after {
  content: "";
  position: absolute;
  display: block;
  bottom: 100%;
  left: 5%;
  margin-left: -5px;
  border-width: 0 10px 8px;
  border-style: solid;
  border-color: #fff transparent;
}

.popup-link {
  color: $color-brand-1;
  text-decoration: none;
  font-weight: bold;
}

.popup-link:hover {
  color: $color-link-hover;
  text-decoration: none;
  font-weight: bold;
}