自訂右鍵選單
自訂右鍵選單
自訂右鍵選單,對於某些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; }
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; }
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"; } }
document.onclick = function(){ //obj为菜单元素DOM对象 obj.style.display = "none"; }
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; } }

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

用法:在JavaScript中,insertBefore()方法用於在DOM樹中插入一個新的節點。這個方法需要兩個參數:要插入的新節點和參考節點(即新節點將要插入的位置的節點)。

JavaScript是一種廣泛應用於Web開發的程式語言,而WebSocket則是一種用於即時通訊的網路協定。結合二者的強大功能,我們可以打造一個高效率的即時影像處理系統。本文將介紹如何利用JavaScript和WebSocket來實作這個系統,並提供具體的程式碼範例。首先,我們需要明確指出即時影像處理系統的需求和目標。假設我們有一個攝影機設備,可以擷取即時的影像數
