zoukankan      html  css  js  c++  java
  • Document

    概述

    以前在网上找过屏蔽右键菜单的代码,也找过屏蔽F12的代码,今天无意之中看到别人的右键菜单很有意思,我也想来搞一个。

    思路

    1. 建立一个菜单并且隐藏起来。
    2. 用window.oncontextmenu屏蔽鼠标右键的默认事件。
    3. 判断鼠标点击事件的类型,如果为右键则在把菜单显示并且移动到鼠标位置。
    4. 点击鼠标左键时,隐藏菜单。

    代码示例

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.js"></script>
        <style>
            li {
                cursor: pointer;
            }
            li:hover {
                text-decoration: underline;
            }
        </style>
    </head>
    <body style="position: relative;">
    <div style="background-color: grey;  500px; height: 500px;"></div>
    <ul class="right" style="display: none;position: absolute;border: 1px solid green">
        <li>喵喵!!</li>
        <li>不准偷看</li>
        <li>关于本站</li>
    </ul>
    
    <script type="text/javascript">
        window.oncontextmenu = function() { return false; };
        $('body').mousedown(function(event) {
            if (event.which === 3) {
                $('.right').css({ 'display': 'block', 'top': event.pageY + 'px', 'left': event.pageX + 'px' });
            }
        });
        $('body').click(function(event) {
            $('.right').css({ 'display': 'none' });
        });
    </script>
    </body>
    </html>
    

    运行测试

    其它

    有一个小bug,就是当把那个长宽500px的div删掉时,就不会触发事件了,原因不明。

    不是position的问题,因为我把这个div的长宽设置为1px后,在远离它的地方点击不会触发事件,在靠近它的地方点击则会触发事件。

    哈哈,原因找到了!并不是没有触发事件,而是因为html的body没有被撑开,所以不能把这个div通过绝对定位移动到body以外

    实测,去掉这个div,然后给body加上这个样式style=" 100%; height: 2000px;"就可以了。

  • 相关阅读:
    串口通信
    PS如何将图片/照片转换为线稿
    merge_image.sh
    remk_dir.sh
    简单监控Tomcat连接池大小的命令以及其他简单命令
    一个挖矿病毒的简单发现历程
    IDEA运行tomcat8.5.35源代码
    mybatis 中 if-test 判断大坑
    浅析前端安全:如何防止XSS攻击
    浅析xss攻击原理、模拟xss攻击及防止xss攻击的方法
  • 原文地址:https://www.cnblogs.com/yangzhou33/p/8598323.html
Copyright © 2011-2022 走看看