0

我正在尝试将“选择菜单”“添加到”DIV。菜单在 DIV 上的“鼠标悬停”上是“prependingTo”。在这个菜单中是带有一些选项的 SELECT。但是当我想选择其他选项时,SELECT 菜单中的选项被隐藏了。这没用。为什么 ?

例子

HTML:

 <div id="add" style='width:200px; background:cyan;'> + + + + + + + + + </div>
 <div id="menu">
     <div style="display:inline-block;">
         <button>1</button>
         <button>2</button>
     </div>
     <div style="display:inline-block;">
         <select id="fs">
            <option value="Arial">Arial</option>
            <option value="Verdana ">Verdana </option>
            <option value="Impact ">Impact </option>
            <option value="Comic Sans MS">Comic Sans MS</option>
         </select>
     </div>

 </div>
 <br>
 <div id="cont">
    <div id="container">
       <div id="divA">1111<br><br>&nbsp;</div>
       <br>
       <div id="divB">2222<br><br>&nbsp;</div>
       <br>
       <div id="divC">33333<br><br>&nbsp;</div>
       <br>
       <div id="divD"><br>&nbsp;</div>
    </div>
 </div>

CSS:

  #container{ padding: 100px;  }
  #menu{  font-size: 10px;  
       position: absolute;
       background-color: none;
       letter-spacing: 0px;
  }
  #divA{ background-color: yellow; }
  #divB{ background-color: red;  }
  .divB{ background-color: red; }
  #divC{ background-color: cyan; }
  #divD{ background-color: brown; }

jQuery:

  $("#add").live("click", function() {
     var timestamp = Date.now();
     $("#container").prepend('<div class="divB" id="'+timestamp+'">'+timestamp+'<br><br></div>');
  });
  $("#container div").live({
     mouseover: function() {
        if( $(this).closest("#menu").length ){ return; }
        $('#menu').prependTo($(this));
     }
  });
4

2 回答 2

1

您可以使用findmethod 代替closestclosest选择元素的最近父元素并且您想查找元素的后代,您的 if 语句总是返回false,还请注意live已弃用,您可以使用on代替。

$(document).on({
        mouseover: function(e) {
            if( $(this).find("#menu").length ){ return; }
            // or if ( $('#menu', this).length ){ return; }
            $('#menu').prependTo($(this));

        }
}, "#container div");

http://jsfiddle.net/h7y3Z/

于 2012-09-24T10:00:35.207 回答
1

像这样试试

$("#container").bind({
    mouseover: function() {
        if( $(this).closest("#menu").length ){ 
            return; 
        }
        $('#menu').prependTo(this);
        $("#container").unbind('mouseover');       
    }
});
于 2012-09-24T10:12:19.190 回答