中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript 自定義html元素鼠標右鍵菜單功能

發布時間:2020-10-16 18:16:28 來源:腳本之家 閱讀:244 作者:授客 欄目:web開發

自定義html元素鼠標右鍵菜單

實現思路

在觸發contextmenu事件時,取消默認行為(也就是阻止瀏覽器顯示自帶的菜單),獲取右鍵事件對象,來確定鼠標的點擊位置,作為顯示菜單的left和top值

編碼實現

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script>
  window.onload = function(){
  var menu = document.getElementById('menu');
  document.body.oncontextmenu = function(e){ // 自定義body元素的鼠標事件處理函數
    var e = e || window.event;
    e.preventDefault(); //阻止系統右鍵菜單 IE8-不支持
    // 顯示自定義的菜單調整位置
    let scrollTop =
        document.documentElement.scrollTop || document.body.scrollTop;// 獲取垂直滾動條位置
    let scrollLeft =
        document.documentElement.scrollLeft || document.body.scrollLeft;// 獲取水平滾動條位置
    menu.style.display = 'block';
    menu.style.left = e.clientX + scrollLeft + 'px';
    menu.style.top = e.clientY + scrollTop + 'px';
  }
  // 鼠標點擊其他位置時隱藏菜單
  document.onclick = function(){
    menu.style.display = 'none';
  }
}
</script>
<style>
  *{
    margin: 0;
    padding: 0;
  }
  p{
    margin-top: 200px; 
  }
  ul li{
    list-style-type: none;
    margin: 10px 0;
    text-align: center;
  }
  #menu{
    border:1px solid #ccc;
    background: #eee;
  position: absolute; // 設置菜單為絕對位置
    width: 100px;
    height: 120px;
    display: none;
  }
</style>
</head>
<body >
  <div id="box" >讓body元素出現滾動條用的div</div>
  <div id="menu">
    <ul>
      <li><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" >分享</a></li>
      <li><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" >收藏</a></li>
      <li><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" >舉報</a></li>
    </ul>
  </div>
</body>
</html>

實現效果

JavaScript 自定義html元素鼠標右鍵菜單功能

總結

以上所述是小編給大家介紹的JavaScript 自定義html元素鼠標右鍵菜單功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

左权县| 泗阳县| 玉环县| 洪泽县| 莱阳市| 鹤庆县| 贵州省| 河源市| 汝阳县| 黑山县| 卢龙县| 高雄市| 罗定市| 兴安盟| 都安| 商丘市| 姜堰市| 道孚县| 临安市| 惠来县| 神农架林区| 瑞安市| 浠水县| 安化县| 夹江县| 来宾市| 石棉县| 渝北区| 璧山县| 阳新县| 大田县| 安阳市| 卢湾区| 阿拉善左旗| 铅山县| 湘潭县| 宁化县| 化隆| 大悟县| 和龙市| 奉新县|