JS+DIV实现自定义html右键菜单

JS+DIV实现自定义html右键菜单,第1张

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<title>JS实现自定义右键菜单</title>

<meta http-equiv="content-type" content="text/htmlcharset=gbk">

<script src="http://api.51ditu.com/js/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="http://api.51ditu.com/" target="_blank">地图api</a>

</div>

<div class="menuitems">

<a href="http://www.51ditu.com/traffic/index.html" target="_blank">实时交通</a>

</div>

<div class="menuitems">

<a href="http://www.51ditu.com" target="_blank">地图搜索</a>

</div>

<div class="menuitems">

<a href="http://nav.51ditu.com" target="_blank">驾驶导航</a>

</div>

<hr>

<div class="menuitems">

<a href="http://uu.51ditu.com" target="_blank">灵图UU</a>

</div>

<div class="menuitems">

<a href="http://lushu.51ditu.com" target="_blank">路书下载</a>

</div>

<hr>

<div class="menuitems">

<a href="http://www.lingtu.com" target="_blank">关于本站</a>

</div>

<div class="menuitems">

<a href="http://emap.51ditu.com/link/link.html" target="_bland">友情链接</a>

</div>

</div>

<div id="container">

<p>右键此区域</p>

</div>

</body>

</html>

思路:

你需要先组织默认的右键事件,

你需要自己制作一个右键图层,

下面是简单的代码:

<style>

* {margin:0 padding:0 list-style:none}

#ul1 li {width:400px background:#CCC border:1px solid black margin:10px float:left line-height:30px text-indent:1em}

#menu {width:150px border:1px solid black border:1px solid black position:absolute left:0 top:0 display:none background:white}

#menu li {padding:3px}

#menu li:hover {background:#CCC}

</style>

<script>

window.onload=function (){

var aLi=document.getElementById('ul1').children

var oMenu=document.getElementById('menu')

var aMenuLi=oMenu.children

for (var i=0 i<aLi.length i++)

{

aLi[i].oncontextmenu=function (ev){

var oEvent=ev || event

oMenu.style.display='block'

oMenu.style.left=oEvent.clientX+'px'

oMenu.style.top=oEvent.clientY+'px'

var _this=this

aMenuLi[0].onclick=function (){

_this.parentNode.removeChild(_this)

}

return false

}

}

document.onclick=function (){

oMenu.style.display='none'

}

}

</script>

</head>

<body>

<ul id="menu">

<li>删除</li>

<li>变成红色</li>

<li>变成绿色</li>

<li>变成黄色</li>

<li>变成蓝色</li>

</ul>

<ul id="ul1">

<li>中国信保原副总戴春宁贪污、受贿、通奸被开除党籍</li>

<li>中纪委原书记贺国强考察贵阳孔学堂(图)</li>

<li>解放军报官微:胡锡进相关微博内容是胡说八道</li>

<li>刘汉向湖北省高院提出上诉 已提交上诉状</li>

<li>澳洲公布疑似马航坠毁噪音 或解MH370失踪之谜</li>

<li>曝京沪高铁上海段地面开裂10cm 回应称不影响运营</li>

<li>朝鲜宣传一农场已建成“社会主义世外桃源”(图)</li>

</ul>

</body>

js右击事件

先贴代码:

注意的两个点是:

①:先取消默认右击事件,event.preventDefault()

②:判断event.Button:0:左键,1:滚轮,2:右键。

值得一说的的是"oncontextmenu"是指右键按下时的作用。

再给一个应用吧:

右击div显示出自己定义的菜单,点击除了div的地方,是默认的右击事件。

代码:

效果自行查看吧,其实也没啥。

原理是,右键的菜单其实是一个隐藏的div,当点击父类div的时候,它出现而已。(貌似这样一说显得这个程序好垃圾啊,_(___)_其实这也是大厦的一块砖,少了它,大厦会塌的)

再给了类似的应用吧,一个点击div消失的效果。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11812595.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存