生成多个图像的mouseover在Firefox中有效,但不是

时间:2010-05-24 19:45:12

标签: javascript

下面的代码允许用户将鼠标悬停在1个对象上,它不仅可以替换对象,还可以在按钮之间显示其他对象。

它在Firefox中很有用,但在Internet Explorer中却不行。

HELP

网页: http://www.isp.ucar.edu/

THX, 特里

if ( < document.images) {

    img1on = new Image();
    img1on.src = "images/buttons/button-beachon-on.gif";
    img1off = new Image();
    img1off.src = "images/buttons/button-beachon.gif";

    img2on = new Image();
    img2on.src = "images/buttons/button-bgs-on.gif";
    img2off = new Image();
    img2off.src = "images/buttons/button-bgs.gif";

    img3on = new Image();
    img3on.src = "images/buttons/button-iam-on.gif";
    img3off = new Image();
    img3off.src = "images/buttons/button-iam.gif";

    img4on = new Image();
    img4on.src = "images/buttons/button-nvia-on.gif";
    img4off = new Image();
    img4off.src = "images/buttons/button-nvia.gif";

    img5on = new Image();
    img5on.src = "images/buttons/button-utls-on.gif";
    img5off = new Image();
    img5off.src = "images/buttons/button-utls.gif";

    img6on = new Image();
    img6on.src = "images/buttons/button-water-on.gif";
    img6off = new Image();
    img6off.src = "images/buttons/button-water.gif";

    img7on = new Image();
    img7on.src = "images/buttons/button-exploratory-on.gif";
    img7off = new Image();
    img7off.src = "images/buttons/button-exploratory.gif";


    // second image that does not appear in original button space
    img1ad = new Image();
    img1ad.src = "images/buttons/beachon-overview-sm.gif";

    img2ad = new Image();
    img2ad.src = "images/buttons/bgs-overview-sm.gif";

    img3ad = new Image();
    img3ad.src = "images/buttons/iam-overview-sm.gif";

    img4ad = new Image();
    img4ad.src = "images/buttons/nvia-overview-sm.gif";

    img5ad = new Image();
    img5ad.src = "images/buttons/utls-overview-sm.gif";

    img6ad = new Image();
    img6ad.src = "images/buttons/water-overview-sm.gif";

    img7ad = new Image();
    img7ad.src = "images/buttons/exploratory-overview-sm.gif";
}

function imgOn(imgName) {
    if (document.images) {
        document[imgName].src = eval(imgName + "on.src");
        document["holder"].src = eval(imgName + "ad.src");
    }
}

function imgOff(imgName) {
    if (document.images) {
        document[imgName].src = eval(imgName + "off.src");
        document["holder"].src = "images/buttons/isp-overview-sm.gif";
    }
}

1 个答案:

答案 0 :(得分:0)

首先,这些函数中的eval完全不需要

function imgOn(imgName) {
    if ( < document.images) {
        document[imgName].src = eval(imgName + "on.src");
        document["holder"].src = eval(imgName + "ad.src");
    }
}

function imgOff(imgName) {
    if ( < document.images) {
        document[imgName].src = eval(imgName + "off.src");
        document["holder"].src = "images/buttons/isp-overview-sm.gif";
    }
}

他们应该阅读

function imgOn(imgName) {
    document.getElementById(imgName).src = window[imgName + "on"].src;
    document.getElementById("holder").src = window[imgName + "ad"].src;
}

function imgOff(imgName) {
    document.getELementById(imgName).src = window[imgName + "off"].src;
    document.getElementById("holder").src = "images/buttons/isp-overview-sm.gif";
}

而不是多个img1on = new Image();后跟window[foo]的调用,你应该这样做

var myImages = {};
myImages["img1on" = new Image();

然后你可以稍后再做

var foo = myImages[imgName + "on"].src;

获取src