当前位置: 首页 > article >正文

前端案例---自定义鼠标右键菜单

 之前右击出现默认的选项菜单,使用evt.preventDefault()把默认的去掉,然后自定义右击的样式

 

 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        ul{
            list-style: none;
            width: 200px;
            padding: 10px;
            border: 1px solid black;
            display: none;
            position: absolute;
        }

        ul li:hover{
            background: blue;
        }
    </style>
</head>
<body>
    <ul id="list">
        <li class="aaa">11111111</li>
        <li class="bbb">22222222</li>
        <li class="ccc">333333333</li>
    </ul>
    <script>
        document.addEventListener("contextmenu",function(evt){
            evt.preventDefault()
            list.style.display = "block"
            var x = evt.clientX
            var y = evt.clientY
            if(x >= document.documentElement.clientWidth-list.offsetWidth)
            x = document.documentElement.clientWidth-list.offsetWidth

            if(y >= document.documentElement.clientHeight-list.offsetHeight)
            y = document.documentElement.clientHeight-list.offsetHeight
            list.style.left = x + "px"
            list.style.top = y + "px"
        })

        // 点击左键消失
        document.addEventListener("click",()=>{
            list.style.display = "none"
        })

        list.onclick = function(){
            console.log("list")
        }
    </script>
</body>
</html>


http://www.kler.cn/a/453062.html

相关文章:

  • Java线程池面试题
  • 【C++】19___set / multiset 容器
  • EasyPoi 使用$fe:模板语法生成Word动态行
  • Kubernetes(k8s)离线部署DolphinScheduler3.2.2
  • 《Java核心技术I》Swing的网格包布局
  • 《计算机组成及汇编语言原理》阅读笔记:p86-p115
  • HTML 新手易犯的标签属性设置错误
  • sentinel学习笔记6-限流降级(上)
  • 创建线程的四种方式
  • 大数据技术原理与应用期末复习-代码
  • 深度学习camp-第J5周:DenseNet+SE-Net实战
  • 定位方式:css
  • 选择排序 冒泡排序 MySQL 架构
  • [python SQLAlchemy数据库操作入门]-08.ORM删除不再需要的股票记录
  • C项目 天天酷跑(下篇)
  • ZCC5090EA适用于TYPE-C接口,集成30V OVP功能, 最大1.5A充电电流,带NTC及使能功能,双节锂电升压充电芯片替代CS5090EA
  • 开源智能工业软件技术发展分析
  • “黄师日报”平安小程序springboot+论文源码调试讲解
  • Spring的注解@Autowired 是什么意思?
  • 【每日学点鸿蒙知识】长时任务、profiler allocation、事件订阅、getTagInfo、NativeWindow
  • 重温设计模式--状态模式
  • 基于Spring Boot的中国戏曲文化传播系统
  • Android 中的生产者-消费者模式实现
  • kubeadm 安装最新 k8s 集群
  • Ubuntu20.4 VPN+Docker代理配置
  • 正则表达式优化之实际应用场景优化