本文实例讲述了JS实现的自定义右键菜单。分享给大家供大家参考。具体如下:
示例1:
运行效果截图:
具体代码如下:
<!DOCTYPE html>
<html>
<head>
<title>JS实现自定义右键菜单</title>
<meta http-equiv=\"content-type\" content=\"text/html; charset=utf-8\">
<script src=\"ajax.js\"></script>
<style type=\"text/css\">
#container {
text-align : center;
width : 500px;
height : 500px;
border : 1px solid blue;
margin : 0 auto;
}
.skin {
width : 100px;
border : 1px solid gray;
padding : 2px;
visibility : hidden;
position : absolute;
}
div.menuitems {
margin : 1px 0;
}
div.menuitems a {
text-decoration : none;
}
div.menuitems:hover {
background-color : #c0c0c0;
}
</style>
<script>
window.onload = function() {
var container = document.getElementById(\'container\');
var menu = document.getElementById(\'menu\');
/*显示菜单*/
function showMenu() {
var evt = window.event || arguments[0];
/*获取当前鼠标右键按下后的位置,据此定义菜单显示的位置*/
var rightedge = container.clientWidth-evt.clientX;
var bottomedge = container.clientHeight-evt.clientY;
/*如果从鼠标位置到容器右边的空间小于菜单的宽度,就定位菜单的左坐标(Left)为当前鼠标位置向左一个菜单宽度*/
if (rightedge < menu.offsetWidth)
menu.style.left = container.scrollLeft + evt.clientX - menu.offsetWidth + \"px\";
else
/*否则,就定位菜单的左坐标为当前鼠标位置*/
menu.style.left = container.scrollLeft + evt.clientX + \"px\";
/*如果从鼠标位置到容器下边的空间小于菜单的高度,就定位菜单的上坐标(Top)为当前鼠标位置向上一个菜单高度*/
if (bottomedge < menu.offsetHeight)
menu.style.top = container.scrollTop + evt.clientY - menu.offsetHeight + \"px\";
else
/*否则,就定位菜单的上坐标为当前鼠标位置*/
menu.style.top = container.scrollTop + evt.clientY + \"px\";
/*设置菜单可见*/
menu.style.visibility = \"visible\";
LTEvent.addListener(menu,\"contextmenu\",LTEvent.cancelBubble);
}
/*隐藏菜单*/
function hideMenu() {
menu.style.visibility = \'hidden\';
}
LTEvent.addListener(container,\"contextmenu\",LTEvent.cancelBubble);
LTEvent.addListener(container,\"contextmenu\",showMenu);
LTEvent.addListener(document,\"click\",hideMenu);
}
</script>
</head>
<body>
<div id=\"menu\" class=\"skin\">
<div class=\"menuitems\">
<a href=\"javascript:history.back();\">后退</a>
</div>
<div class=\"menuitems\">
<a href=\"javascript:history.back();\">前进</a>
</div>
<hr>
<div class=\"menuitems\">
<a href=\"\" target=\"_blank\">地图api</a>
</div>
<div class=\"menuitems\">
<a href=\"\" target=\"_blank\">实时交通</a>
</div>
<div class=\"menuitems\">
<a href=\"\" target=\"_blank\">地图搜索</a>
</div>
<div class=\"menuitems\">
<a href=\"\" target=\"_blank\">驾驶导航</a>
</div>
<hr>
<div class=\"menuitems\">
<a href=\"\" target=\"_blank\">灵图UU</a>
</div>
<div class=\"menuitems\">
<a href=\"\" target=\"_blank\">路书下载</a>
</div>
<hr>
<div class=\"menuitems\">
<a href=\"\" target=\"_blank\">关于本站</a>
</div>
<div class=\"menuitems\">
<a href=\"\" target=\"_bland\">友情链接</a>
</div>
</div>
<div id=\"container\">
<p>右键此区域</p>
</div>
</body>
</html>
其中ajax.js代码如下:
希望本文所述对大家的javascript程序设计有所帮助。
本文地址:https://www.stayed.cn/item/11642
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我