我有一个简单的事件监听器,我试图将变量传递给一个函数,但是它不起作用......这就是我所拥有的:
window.onload = function () {
document.getElementById('cursor').addEventListener("mousedown", mousePos, false);
}
function mousePos(e) {
var x = e.clientX;
var y = e.clientY;
document.getElementById('cursor').addEventListener("mousemove", function () {
mousemoveCalc(x, y);
}, false);
}
function mousemoveCalc(e, x, y) {
console.log(e);
console.log(x); //undefined
console.log(y); //undefined
}
我未定义x
和y
,但我不知道如何解决它= /它们未定义但是在mousePos = /
我该如何解决这个问题?
答案 0 :(得分:0)
看到这个小提琴,看看它是否接近你要找的东西。 http://jsfiddle.net/cF6fE/2/
var posx = 0;
var posy = 0;
window.onload = function() {
document.getElementById('cursor').addEventListener("mousedown", mousePos, false);
}
function mousePos(e) {
posx = e.clientX;
posy = e.clientY;
document.getElementById('cursor').addEventListener("mousemove", mousemoveCalc);
}
function mousemoveCalc(e) {
console.log(e);
var x = e.clientX;
var y = e.clientY;
var xOffset = posx-x;
var yOffset = posy-y;
console.log(x);
console.log(y);
console.log(xOffset);
console.log(yOffset);
}
function mousePos(e) {
var posx = e.clientX;
var posy = e.clientY;
document.getElementById('cursor').addEventListener("mousemove", mousemoveCalc.bind(this, posx,posy));
}
function mousemoveCalc(xax,yax,e) {
console.log(e);
var x = e.clientX;
var y = e.clientY;
var xOffset = xax-x;
var yOffset = yax-y;
console.log(x); //undefined
console.log(y); //undefined
console.log(xOffset); //undefined
console.log(yOffset); //undefined
}
function mousePos(e) {
var posx = e.clientX;
var posy = e.clientY;
document.getElementById('cursor').addEventListener("mousemove", function() {
(function(x, y) {
mousemoveCalc(x, y)
})(posx, posy)
});
}
function mousemoveCalc(xax, yax) {
var x = event.clientX;
var y = event.clientY;
var xOffset = xax - x;
var yOffset = yax - y;
console.log(xax);
console.log(yax);
document.getElementById('cursor').innerText = xax + '-' + yax + '|' + xOffset + '-' + yOffset;
console.log(xOffset);
console.log(yOffset);
}