自定義右鍵菜單

来源:http://www.cnblogs.com/shinhwazt/archive/2016/10/28/6009619.html
-Advertisement-
Play Games

自定義右鍵菜單 技術一般水平有限,有什麼錯的地方,望大家指正。 自定義右鍵菜單,對於一些ERP系統,功能操作比較多,所以我們通常把常用的幾個功能放在自定義的右鍵菜單里方便用戶使用。 實現自定義菜單很簡單,首先我們要屏蔽原始的右鍵菜單,自定義菜單出現在滑鼠的位置,點擊隱藏自定義菜單,過程就是這樣的。 ...


自定義右鍵菜單

  技術一般水平有限,有什麼錯的地方,望大家指正。   

  自定義右鍵菜單,對於一些ERP系統,功能操作比較多,所以我們通常把常用的幾個功能放在自定義的右鍵菜單里方便用戶使用。

  實現自定義菜單很簡單,首先我們要屏蔽原始的右鍵菜單,自定義菜單出現在滑鼠的位置,點擊隱藏自定義菜單,過程就是這樣的。

*{margin:0;padding:0}
a{text-decoration:none}
ul li{list-style:none}
.menu{border:1px solid black;border-radius:5px;display:inline-block;position:fixed;top:100px;left:550px;
overflow:hidden;padding-bottom:10px;box-shadow:0 0 10px 0;z-index:999;display:none;background:white} .menu ul li{height:30px;width:100%} .menu ul li a{height:30px;display:inline-block;width:100%;text-align:left;line-height:30px;padding:5px 10px} .menu li a:hover{background-color:#EEF5E2}
  <div class="menu" id="demo">
    <ul>
        <li><a href="#">向錄入員發送消息</a></li>
        <li><a href="#">發送選中作業</a></li>
        <li><a href="#">設置作業狀態</a></li>
        <li><a href="#">哈哈哈哈哈</a></li>
        <li><a href="#">嘻嘻嘻嘻嘻</a></li>
        <li><a href="#">呵呵呵呵呵呵</a></li>
    </ul>
  </div>

  1.屏蔽原始的右鍵菜單

  在JS中提供了一個事件來完成這件事就是oncontextmenu,這個是事件綁定的區域在點擊右鍵時將不會再出現原始右鍵菜單:

document.oncontextmenu = function(){
  return false;
}

  2.獲取自定義菜單的大小

  自定義菜單初始是隱藏的,對於隱藏的元素我們是沒有辦法來獲取它的寬高的。我們可以先將菜單元素設置為visibility:hidden,獲取到元素的寬高後在去掉這個屬性:

  function getHideDOMWH(obj){
      //obj為菜單元素的DOM對象
      var wh = {};
      obj.style.visibility = "hidden";
      wh.w = obj.scrollWidth;
      wh.h = obj.scrollHeight;
      obj.style.visibility = null;
      return wh;
  }

  3.自定義菜單出現在當前滑鼠的位置

  首先我們就需要獲取當前的滑鼠的位置,當前滑鼠位置就是自定義菜單出現的位置。同時要註意距右側距離或者距下麵的距離不足以顯示菜單的情況:

document.onmousedown = function(e){
    //obj為菜單元素DOM對象
    var e = e || window.event;
    if(e.button==2){
        var left = e.clientX;
        var top = e.clientY;
        var windowHeight = document.body.scrollHeight;
        var windowWidth = document.body.scrollWidth;
        var wh = getHideDOMWH(obj);
        var contentHeight = wh.h;
        var contentWidth = wh.w;
        obj.style.left = windowWidth-left>contentWidth?left+"px":windowWidth-contentWidth+"px";
        obj.style.top = windowHeight-top>contentHeight?top+"px":top-contentHeight+"px";
        obj.style.display = "inline-block";
    }
}

  當瀏覽器視窗的寬度減去游標點擊時距離左邊的距離小於菜單的寬度的時候,說明游標距離右邊的距離已經不足以顯示菜單了,我們就讓菜單的緊貼右側,此時菜單的left值為瀏覽器視窗的寬度減去菜單的寬度。當瀏覽器視窗的高度減去游標距離上側的距離小於菜單的高度時,說明此時游標距離下麵的距離不足以顯示菜單了,此時菜單的top值為游標距離上面的距離減去菜單的高度。

  4.無論是點擊菜單元素還是其他元素都隱藏菜單

document.onclick = function(){
    //obj為菜單元素DOM對象
    obj.style.display = "none";
}

  為了使用方便我們可以將上面的這個過程封裝成一個方法,或者在原生JS的Element的原型上擴展一個方法(IE7及以下是會報錯的),或者是JQ的原型上,這裡我們封裝一個方法。

  function contextMenu(obj){
      //obj為DOM對象
      document.oncontextmenu = function(){
          return false;
      }
      document.onmousedown = function(e){
          var e = e||window.event;
          if(e.button==2){
              var mouseX = e.clientX;
              var mouseY = e.clientY;
              var wh = getObjWH(obj);
              var contentW = wh.w;
              var contentH = wh.h;
              var documentW = document.body.scrollWidth;
              var documentH = document.body.scrollHeight;
              obj.style.left = documentW-mouseX<contentW?documentW-contentW+"px":mouseX+"px";
              obj.style.top = documentH-mouseY<contentH?mouseY-contentH+"px":mouseY+"px";
              obj.style.display = "inline-block";
          }
          
      }
      document.onclick = function(){
          obj.style.display = "none";
      }
      function getObjWH(obj){
          var wh = {};
          obj.style.visibility = "hidden";
          wh.w = obj.scrollWidth;
          wh.h = obj.scrollHeight;
          obj.style.visibility = null;
          return wh;
      }
  }

  我們所有的事件都是綁定在document上的而事件我們通常會使用冒泡機制,如果我們在某個元素上設置了取消冒泡則會有一些問題,我們需要做一些針對性的處理。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、前言 1.1、什麼是輸入驗證?為什麼需要輸入驗證? 在上一篇文章中,我們學習了數據類型轉換,我們提到了表示層數據處理的兩個方法,也提到了用戶輸入數據需要進行類型轉換才能得到我們想要的數據,那麼,我們怎麼確定類型轉換後的數據,是我們想要的數據呢?這裡有點繞。你可以這樣想:一個成年男子年齡是18歲, ...
  • 以需求用例為基,抽象介面,Case&Coding兩條線並行,服務(M)&消費(VC)分離,單元、介面、功能、集成四層質量管理,自動化集成、測試、交付全程支持。 3個大階段(需求分析階段、研發準備階段、研發測試階段)16個小歷程(*)確定好邊界,明確好對接產物,做好服務管理。 基於SOA架構的TDD測 ...
  • 這個問題是不可迴避的 ...
  • 一、前言 筆者一直覺得,學習一個知識點,你首先要明白,這東西是什麼?有什麼用?這樣你才能瞭解。好了,不說廢話。 1.1、類型轉換為何存在?什麼是類型轉換? 在MVC框架中,都是屬於表示層解決方案,都需要負責收集用戶請求的參數,並且將請求參數傳給應用的控制器組件,但是,這裡有一個問題,客戶端提交的請求 ...
  • 用Sublime Text蠻久了,配置配來配去的,每次換電腦都得重頭再配過,奈何人老了腦子不中用了,得好好整理一些,下次換電腦就有得參考了.. 同事說,他的WebStorm簡直太方便,自身集成了很多方便的工具,不用配置太多 哈哈哈哈但我還是更喜歡用ST 如果要將Sass編譯成css文件,安裝相應的編 ...
  • 當前的應用設計風格趨於Flat扁平化,很多基於BootStrap實現了很多UI非常漂亮的管理界面(Bootstrap admin template)。 此核心文件開源在Github:https://github.com/JackWangCUMT/AdminLTE-Menu-Generate。首先看一 ...
  • 各位好,今天要來介紹如何簡單的修改網站上AngularJS相關Application的內容 進而做到某些效果。(警告!所有的Web Application都應該在後端加上相關驗證) 透過本篇你可以簡單的瞭解到以下 1.如何查找相關的ng物件 2.如何利用ng.element與ng.injector來 ...
  • <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <style type="text/css"> img { margin: 100px 0px 0px 500px; } #div2 { margin-left: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...