Ответ 1
Вы пытаетесь получить позицию указателя мыши relative
к элементу (или) просто указателю мыши.
Попробуйте эту демонстрацию: http://jsfiddle.net/AMsK9/
Изменить:
1) event.pageX
, event.pageY
дает вам относительный документ позиции мыши!
Ссылка: http://api.jquery.com/event.pageX/
http://api.jquery.com/event.pageY/
2) offset()
: дает положение смещения элемента
Ссылка: http://api.jquery.com/offset/
3) position()
: он дает относительное положение элемента i.e.,
Рассмотрим элемент, встроенный внутри другого элемента
пример:
<div id="imParent">
<div id="imchild" />
</div>
Ссылка: http://api.jquery.com/position/
HTML
<body>
<div id="A" style="left:100px;"> Default <br /> mouse<br/>position </div>
<div id="B" style="left:300px;"> offset() <br /> mouse<br/>position </div>
<div id="C" style="left:500px;"> position() <br /> mouse<br/>position </div>
</body>
JavaScript
$(document).ready(function (e) {
$('#A').click(function (e) { //Default mouse Position
alert(e.pageX + ' , ' + e.pageY);
});
$('#B').click(function (e) { //Offset mouse Position
var posX = $(this).offset().left,
posY = $(this).offset().top;
alert((e.pageX - posX) + ' , ' + (e.pageY - posY));
});
$('#C').click(function (e) { //Relative ( to its parent) mouse position
var posX = $(this).position().left,
posY = $(this).position().top;
alert((e.pageX - posX) + ' , ' + (e.pageY - posY));
});
});