jQuery 1.3.2 и IE 8 проблема с hide () и show () - PullRequest
0 голосов
/ 27 февраля 2010

Может кто-нибудь сказать мне, пожалуйста, почему следующий пример работает в Firefox, но не в IE 8? Только content_1 работает правильно в IE 8.

Thx Vijy.

<script type="text/javascript">

$(function(){
    $("#sortable").sortable({handle: '#dragable'});
});


$(function(){

   var v;

  $('div[id^="content_"]').hover(

        function () {

        v = $(this).attr('id');
            $('#'+v+' #menu').show();
            $('#'+v+' #dragable').show();
        },
        function () {
            $('#'+v+' #menu').hide();
            $('#'+v+' #dragable').hide();
        }
    );

});

</script>


<body>

<div id='sortable'>

    <div id='content_1'>

        <div id='menu' style='display:none;'>
            <div>edit</div>
            <div>add</div>
            <div>delete</div>
        </div>

        <div id='content'>Content_1</div>

        <div id='dragable' style='display:none;'>[drag]</div>
    </div>




    <div id='content_2'>

        <div id='menu' style='display: none;'>
            <div>edit</div>
            <div>add</div>
            <div>delete</div>
        </div>

        <div id='content'>Content_2</div>

        <div id='dragable' style='display:none;'>[drag]</div>
    </div>





    <div id='content_3'>

        <div id='menu' style='display: none;'>
            <div>edit</div>
            <div>add</div>
            <div>delete</div>
        </div>

        <div id='content'>Content_3</div>

        <div id='dragable' style='display: none;'>[drag]</div>
    </div>

</div>



</body>

Ответы [ 2 ]

2 голосов
/ 27 февраля 2010

идентификаторы должны быть уникальными на странице (html spec [1]); у вас есть 2 #menu, #content и т. д. Измените их, например, на. <div class="menu"> и ваш селектор на .menu - это должно сработать.

Кстати, вы можете упростить ваш обратный вызов при наведении курсора find [2]:

function () {
    $(this).find('.menu, .dragable').show(); 
}

1: http://www.w3.org/TR/html401/struct/global.html#h-7.5.2
2: http://api.jquery.com/find/

0 голосов
/ 27 февраля 2010

Нельзя иметь несколько элементов с одинаковым идентификатором, это недопустимый HTML, идентификаторы должны быть уникальными Ваши элементы меню должны быть классом, а не идентификатором, например:

<div id='content_1'>

    <div class='menu' style='display: none;'>
        <div>edit</div>
        <div>add</div>
        <div>delete</div>
    </div>

    <div class='content'>Content_2</div>

    <div class='dragable' style='display:none;'>[drag]</div>
</div>

И jQuery, как это:

$(function(){
  $('div[id^="content_"]').hover(
        function () {
          $(this).find('.menu, .dragable').show();
        },
        function () {
          $(this).find('.menu, .dragable').hide();
        }
    );
});
...