-1

我正在研究Adam Maschek 出色的图像地图工具的改编版本。我添加的新功能是左/上/宽/高输入框,以便您可以对热点位置/大小进行像素控制。我已经让它在 FF 和 Chrome 中运行良好,但我遇到的问题是在 IE 7/8 中,它不会在更改时检索输入框的值。

这是发生问题的函数:

function gui_dimension_change(e) {

function changeAreaPos(areaNum, inputVal, cssAttrib, coordPos) {
var coordsBox = document.getElementsByClassName('img_coords')[areaNum],
    newCoordsVal = coordsBox.value.split(","),
    newWidth = "",
    newHeight = "",
    imCode = imcodeContainer.value,
    pattern = imCode.match(/\d+,\d+,\d+,\d+/g);

    myimgmap.areas[areaNum].style[cssAttrib] = inputVal;

    if (cssAttrib === "left" || cssAttrib === "top") {
        myimgmap.areas[areaNum].label.style[cssAttrib] = inputVal;
        newCoordsVal[coordPos] = inputVal;
    } else if (cssAttrib === "width") {
        myimgmap.areas[areaNum].width = inputVal;
        newWidth = parseInt(newCoordsVal[0]) + parseInt(inputVal);
        newCoordsVal[coordPos] = newWidth;
    } else if (cssAttrib === "height") {
        myimgmap.areas[areaNum].height = inputVal;
        newHeight = parseInt(newCoordsVal[1]) + parseInt(inputVal);
        newCoordsVal[coordPos] = newHeight;
    }

    newCoordsVal = newCoordsVal.join(",");
    myimgmap.areas[areaNum].lastInput = newCoordsVal;
    coordsBox.value = newCoordsVal;

    imCode = imCode.replace(pattern[areaNum], newCoordsVal);
    imcodeContainer.value = imCode;

};

    // alert(this);
    // alert(this.parentNode);
    // alert(this.parentNode.id);

var inputParent = this.parentNode,
    inputVal = this.value,
    whichBox = this.name,
    areaNum = inputParent.id.replace("img_area_", ""),
    imcodeContainer = document.getElementById('html_container');

switch(whichBox)
{
    case "img_left":
        changeAreaPos(areaNum, inputVal, "left", 0);
    break;
    case "img_top":
        changeAreaPos(areaNum, inputVal, "top", 1);
    break;
    case "img_width":
        changeAreaPos(areaNum, inputVal, "width", 2);
    break;
    case "img_height":
        changeAreaPos(areaNum, inputVal, "height", 3);
    break;
}

}

函数调用如下:

myimgmap.addEvent(props[id].getElementsByTagName('input')[5], 'change', gui_dimension_change);
myimgmap.addEvent(props[id].getElementsByTagName('input')[6], 'change', gui_dimension_change);
myimgmap.addEvent(props[id].getElementsByTagName('input')[7], 'change', gui_dimension_change);
myimgmap.addEvent(props[id].getElementsByTagName('input')[8], 'change', gui_dimension_change);

所以在change事件上我不能用this.parentNode设置inputParent,也不能用this.value获取输入框的值。适用于 FF/Chrome 但不适用于 IE 7/8,任何想法为什么 IE 与 parentNode 存在问题并获得价值?

4

1 回答 1

1

好的,我想出了解决方案,以防万一有人关心。这完全是因为 IE 处理事件目标的方式与其他浏览器不同,所以我做了以下操作:

var obj = (myimgmap.isMSIE) ? window.event.srcElement : e.currentTarget;

并使用 obj 而不是这个。

愚蠢的IE!!!

于 2012-08-15T14:40:37.500 回答