如使用原生js自定义右键菜单
【摘要】 1、右键菜单触发的基本过程实现自定义右键菜单我们首先需要了解以下内容:浏览器默认的右键菜单触发的基本过程单击右键,菜单出现菜单出现,鼠标箭头一直在菜单左上角再换个位置点击右键,原菜单消失,新菜单出现在指定位置点击左键,中键,菜单消失以上为大致实现过程,不全面,仅供参考也许文字过于抽象,我们来看看代码吧:2、HTML结构<!--start右键菜单的结构--><div id="rightme...
1、右键菜单触发的基本过程
实现自定义右键菜单我们首先需要了解以下内容:
浏览器默认的右键菜单触发的基本过程
- 单击右键,菜单出现
- 菜单出现,鼠标箭头一直在菜单左上角
- 再换个位置点击右键,原菜单消失,新菜单出现在指定位置
- 点击左键,中键,菜单消失
以上为大致实现过程,不全面,仅供参考
也许文字过于抽象,我们来看看代码吧:
2、HTML结构
3、CSS样式
.rightmenu设置display:none是因为右键菜单本身是隐藏了因为点击了才出现,倘若不加这句,菜单会出现在页面的左上角。
3、js实现过程
分析:
①:浏览器本身就有右键菜单,我们也要做右键菜单,所以应当阻止浏览器的右键,这里可以用到preventDefault(),这个方法有着阻止默认事件的功能,科普一下,什么是默认事件:
例如:
可以知道这是可以跳转到百度的,所以是有个跳转时间的,这个事件我们没有去用js实现,他是默认的,所以称之为默认事件,同理,浏览器右键菜单。②前面我们说了菜单出现,鼠标箭头一直在菜单左上角,这是怎么实现的呢,这涉及到event里面的事件发生坐标了,我们点击的位置就是我们右键点击事件发生的位置,可以用坐标来解释这个位置,clientX(事件发生点和可视区域的位置),offsetX(事件发生点和父级元素的位置),pageX(事件发生点和页面的位置),screenX(事件发生点和屏幕的位置),这里我们用offsetX/Y,因为我们是在BOW中点击,所以具体原因大家百度一下就直道了,我们还是看代码吧,代码里标注的很详细。
以上仅供参考,更多的功能实现都是差不多的原理,好了,结束了。
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)