Я разработал контекстное меню правой кнопкой мыши в javascript для таблицы. Положение контекстного меню находится внизу курсора для каждой строки таблицы. Последняя строка таблицы находится в конце страницы. Теперь при щелчке правой кнопкой мыши Строка контекстного меню идет вниз, но он должен отображаться вверху курсора. Помогите, пожалуйста,
function ContextShow(event) {
event = event || window.event;
var m = getMousePosition(event);
var s = getScrollPosition(event);
var client_height = document.body.clientHeight;
var display_context = document.getElementById('context_menu');
if(replaceContext){
display_context.style.display = "block";
display_context.style.left = m.x + s.x + "px";
display_context.style.top = m.y + s.y + "px";
replaceContext = false;
}}
function getMousePosition (e){
e = e || window.event;
var position = {
'x' : e.clientX,
'y' : e.clientY
}
return position;}
function getScrollPosition(){
var x = 0;
var y = 0;
if( typeof( window.pageYOffset ) == 'number' ) {
x = window.pageXOffset;
y = window.pageYOffset;
} else if( document.documentElement && ( document.documentElement.scrollLeft || document.documentElement.scrollTop ) ) {
x = document.documentElement.scrollLeft;
y = document.documentElement.scrollTop;
} else if( document.body && ( document.body.scrollLeft || document.body.scrollTop ) ) {
x = document.body.scrollLeft;
y = document.body.scrollTop;
}
var position = {
'x' : x,
'y' : y
}
return position;
}
Здесь contextShow будет отображать контекстное меню щелчка правой кнопкой мыши в зависимости от положения мыши с использованием getMousePosition (event); и getScrollPosition (event);