在下面的代码中,我尝试为图表创建缩放功能。我在IE上测试它并且它工作但是当我在FF上尝试它时,似乎浏览器不会取消默认操作并尝试拖动整个图像。我无法弄清楚为什么它不起作用! JsFiddle
<img onmousedown="startDrag" onmousemove="drag" onmouseup="stopDrag" src="ChartImageSource">
MouseDownPosition = null;
startDrag = function (s, e) {
if (!this.MouseDownPosition && e.which == 1) {
this.MouseDownPosition = {
x: e.clientX,
y: e.clientY
};
this.Box = document.createElement("div");
$(this.Box).attr('id', 'zoomBox').css({ 'border-style': 'solid', 'border-color': 'black', 'border-width': '1px', 'position': 'absolute', 'z-index': '1000', 'left': e.clientX + 'px', 'top': e.clientY + 'px', 'width': '0px', 'height': '0px' });
$(s).parent().append(this.Box);
}
};
drag = function (s, e) {
if (this.MouseDownPosition) {
e.preventDefault();
var initX = this.MouseDownPosition.x;
var initY = this.MouseDownPosition.y;
var curX = e.clientX;
var curY = e.clientY;
var left;
var top;
var width;
var height;
if (curX - initX >= 0) {
width = curX - initX + 'px';
left = initX + 'px';
} else {
width = -curX + initX + 'px';
left = curX + 'px';
}
if (curY - initY >= 0) {
height = curY - initY + 'px';
top = initY + 'px';
} else {
height = -curY + initY + 'px';
top = curY + 'px';
}
$(this.Box).css({ 'width': width, 'height': height, 'left': left, 'top': top });
}
};
stopDrag = function (s, e) {
if (this.MouseDownPosition) {
var initX = this.MouseDownPosition.x;
var initY = this.MouseDownPosition.y;
var curX = e.clientX;
var curY = e.clientY;
var curOffX = e.offsetX;
var curOffY = e.offsetY;
var initOffX = ((curX - initX) ? initX - curX : -(initX - curX)) + curOffX;
var initOffY = ((curY - initY) ? initY - curY : -(initY - curY)) + curOffY;
var MinPixX = initOffX <= curOffX ? initOffX : curOffX;
var MaxPixX = initOffX >= curOffX ? initOffX : curOffX;
var MinPixY = initOffY <= curOffY ? initOffY : curOffY;
var MaxPixY = initOffY >= curOffY ? initOffY : curOffY;
s.parentNode.removeChild(this.Box);
this.MouseDownPosition = null;
}
};
答案 0 :(得分:1)
您通常需要事件处理程序中的return false;
来绕过默认操作。
或者,jQuery提供preventDefault()
和stopPropagation()
函数。您可能需要同时调用它们,但是当您不使用jQuery时,IMO非常详细且替代(return false;
)也可以。
答案 1 :(得分:1)
e.preventDefault();
还不够。您也需要致电e.stopPropagation();
。