這篇文章主要介紹了JS如何實(shí)現(xiàn)自定義右鍵菜單,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
做網(wǎng)站、網(wǎng)站制作的開(kāi)發(fā),更需要了解用戶,從用戶角度來(lái)建設(shè)網(wǎng)站,獲得較好的用戶體驗(yàn)。創(chuàng)新互聯(lián)多年互聯(lián)網(wǎng)經(jīng)驗(yàn),見(jiàn)的多,溝通容易、能幫助客戶提出的運(yùn)營(yíng)建議。作為成都一家網(wǎng)絡(luò)公司,打造的就是網(wǎng)站建設(shè)產(chǎn)品直銷的概念。選擇創(chuàng)新互聯(lián),不只是建站,我們把建站作為產(chǎn)品,不斷的更新、完善,讓每位來(lái)訪用戶感受到浩方產(chǎn)品的價(jià)值服務(wù)。示例:
假設(shè)我要把上面這個(gè)div設(shè)置為右鍵菜單,先隨意美化一下。
原理就是利用contextmenu事件,右鍵點(diǎn)擊時(shí),會(huì)觸發(fā)這個(gè)事件時(shí),該事件對(duì)象可以獲得鼠標(biāo)距離頁(yè)面左上角的距離clientX和clientY,
我們可以利用這兩個(gè)屬性,來(lái)控制div的水平,垂直偏移量,并且返回false,取消事件的默認(rèn)行為,來(lái)模擬瀏覽器的右鍵菜單。
document.oncontextmenu=function(e){ var x=e.clientX+'px'; var y=e.clientY+'px'; var node=document.querySelector('#menu'); node.style.left=x; node.style.top=y; node.style.width=100+'px'; node.style.height=100+'px'; return false; //很重要,不能讓瀏覽器顯示自己的右鍵菜單 }現(xiàn)在是關(guān)閉部分,關(guān)閉右鍵菜單的方式,通常是在空白區(qū)域點(diǎn)擊左鍵。
document.onclick=function(e){ if(e.target.id!='menu') { var node=document.querySelector('#menu'); node.style.width=0; node.style.height=0; } }這僅僅是一個(gè)基本的思路的,核心就是contextmenu事件。你可以在此基礎(chǔ)上使用CSS隨意美化升級(jí),加入類似于transition等屬性,來(lái)實(shí)現(xiàn)動(dòng)畫(huà)效果。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“JS如何實(shí)現(xiàn)自定義右鍵菜單”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián)建站,關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
網(wǎng)頁(yè)名稱:JS如何實(shí)現(xiàn)自定義右鍵菜單-創(chuàng)新互聯(lián)
網(wǎng)頁(yè)鏈接:http://weahome.cn/article/ieejj.html