2012-05-21 112 views
0

http://www.kars4kids.org/charity/v2/nirangahtml/program_pop/meet_animals.aspjQuery的悬停和选择的问题

上面的链接, 当我选择在下面图标之一。 它是对选定状态的更改,但问题是我需要限制悬停效果并进一步选择该图标。 (因为我正在使用图像更改)。

下面是我完整的jQuery代码。

$(document).ready(function(){ 
    $('#animal_content_text_horse').css("display", "block"); 
    $('#animal_pic_horse_span').css("display", "block"); 
    $('#page_animal_img_horse').css("display", "block"); 

$('.animal_thumb_link').each(function() { 

    $(this).click(function(e) { 
    e.preventDefault(); 
    default_set($(this).attr('id')); 

    $(".animal_thumb_link").removeClass("thumbselected"); 
    $(this).addClass("thumbselected"); 
    $(".animal_thumb_link").find('img').addClass("imgHoverable"); 
    $(this).find('img').removeClass("imgHoverable"); 

    }); 

}); 

     // Change the image of hoverable images 
     $(".imgHoverable").hover(function() { 
      var hoverImg = HoverImgOf($(this).attr("src")); 
      $(this).attr("src", hoverImg).hide().fadeIn(0); 
     }, function() { 
      var normalImg = NormalImgOf($(this).attr("src")); 
      $(this).attr("src", normalImg).show(); 
     } 
     ); 


    function HoverImgOf(filename) 
    { 
     var re = new RegExp("(.+)\\.(gif|png|jpg)", "g"); 
     return filename.replace(re, "$1_r.$2"); 
    } 
    function NormalImgOf(filename) 
    { 
     var re = new RegExp("(.+)_r\\.(gif|png|jpg)", "g"); 
     return filename.replace(re, "$1.$2"); 
    } 

}); 

function default_set(obj12){ 

var arr = ["horse_content", "camel_content", "peacock_content", "goat_content", "donkey_content", "rooster_content", "sheep_content", "alpacas_content", "cynthia_content", "rabbit_content", "cow_content"]; 
var arr2 = ["../images/horse_thumb.gif", "../images/camel_thumb.gif", "../images/peacock_thumb.gif", "../images/goat_thumb.gif", "../images/donkey_thumb.gif", "../images/rooster_thumb.gif", "../images/sheep_thumb.gif", "../images/alpacas_thumb.gif", "../images/cynthia_thumb.gif", "../images/rabbit_thumb.gif", "../images/cow_thumb.gif"]; 


for (var i = 0; i <= arr.length; i++) { 
if (arr[ i ] === obj12) { 
    old_url = $("#" + obj12).children('img').attr('src'); 
    new_url = old_url.replace(/thumb/,'thumb_r'); 
    $("#" + obj12).children('img').attr('src',new_url); 
}else{ 
    $('#' +arr[ i ]).children('img').attr('src',arr2[ i ]); 
} 

} 



} 


function load_page(obj1,obj2,obj3){ 
    /* detect current div if so hide */ 
    current_pagepharadiv = document.getElementById("pagepharadiv_hidden").value; 
    current_pageheadertext = document.getElementById("pageheadertext_hidden").value; 
    current_pageimage = document.getElementById("pageimage_hidden").value; 

    $('#' + current_pagepharadiv).css("display", "none"); 
    $('#' + current_pageheadertext).css("display", "none"); 
    $('#' + current_pageimage).css("display", "none"); 

    image_hover(obj1); 
    image_hover(obj2); 
    $('#' + obj3).fadeIn("fast"); 

    //image_hover(obj3); 
    //$('#' + obj1).fadeIn("fast"); 
    //$('#' + obj2).fadeIn("fast"); 
    document.getElementById("pagepharadiv_hidden").value = obj1; 
    document.getElementById("pageheadertext_hidden").value = obj2; 
    document.getElementById("pageimage_hidden").value = obj3; 

} 

可以请你们建议, 干杯!

+0

为什么在地球上你不使用CSS的一些...代码简单易懂是简单的编辑 –

+0

我很抱歉家伙,我没有想到有一个投票等。选项。我的错。这不会再发生。非常感谢你指出这一点。干杯! –

回答

2

在我看来,你真的让事情变得比他们需要的更复杂。这是我将如何实现页面:

  • 底广场作为div的,用css使图片透明的PNG
  • 更改底部方形颜色:悬停
  • 生成每个动物在服务器上的整个顶部内容一个div:所以你有一个接一个的11个div,而不是在3个地方隐藏/显示东西。在我的代码示例下面我想他们有类animal-content
  • 添加每个顶部div的ID作为HTML5数据属性对应拇指链接

这样,所有你需要的jQuery做的是:

$(".animal_thumb_link").click(function() { 
    var topId = $(this).data("topId"); 
    $(".animal_thumb_link").removeClass("thumbselected"); 
    $(this).addClass("thumbselected"); 

    $(".animal-content").toggle(function() { return this.id === topId; }); 
}); 
+0

感谢您的解决方案,我根据您的建议进行了一些更改。它现在工作正常。非常感谢你。 –