工作中碰見了奇葩的需求(見多了,也就不奇葩了哈哈)—— 用戶讓加上鼠標(biāo)右鍵點(diǎn)擊事件
1、oncontextmenu 事件
定義?:oncontextmenu 事件在元素中用戶右擊鼠標(biāo)時(shí)觸發(fā)并打開上下文菜單。
HTML :
<element?oncontextmenu="myScript">
?JavaScript :
object.oncontextmenu=function(){
myScript
};
?JavaScript 中, 使用 addEventListener() 方法:
object.addEventListener("contextmenu",?myScript);
?注意:?Internet Explorer 8 及更早 IE 瀏覽器版本不支持?addEventListener()?。
2、JS實(shí)例
添加右擊事件 阻止默認(rèn)行為—— oncontextmenu /?contextmenu
document.addEventListener("oncontextmenu",function(evt){
console.log("右鍵單擊,自定義右鍵菜單")
evt.preventDefault()
})
注意:所有瀏覽器都支持 oncontextmenu 事件,?contextmenu?元素只有 Firefox 瀏覽器支持。
3、Vue實(shí)例
? ? ? ?在 Vue.js 中,要實(shí)現(xiàn)右鍵點(diǎn)擊事件,可以使用 Vue 的 contextmenu
指令來監(jiān)聽上下文菜單事件。這個(gè)指令會(huì)在用戶右鍵點(diǎn)擊元素時(shí)觸發(fā)。以下是一個(gè)示例:
HTML :
<div @contextmenu="showContextMenu" class="right-clickable">
Right-click me
<div v-if="contextMenuVisible" class="context-menu">
<!-- 右鍵菜單的內(nèi)容 -->
<ul>
<li @click="menuItemClicked('Option 1')">Option 1</li>
<li @click="menuItemClicked('Option 2')">Option 2</li>
<li @click="menuItemClicked('Option 3')">Option 3</li>
</ul>
</div>
</div>
?JavaScript :
export default {
data() {
return {
contextMenuVisible: false,
contextMenuPosition: { x: 0, y: 0 }
};
},
methods: {
showContextMenu(event) {
// 阻止默認(rèn)右鍵菜單
event.preventDefault();
// 獲取右鍵點(diǎn)擊的位置
this.contextMenuPosition.x = event.clientX;
this.contextMenuPosition.y = event.clientY;
// 顯示右鍵菜單
this.contextMenuVisible = true;
},
hideContextMenu() {
// 隱藏右鍵菜單
this.contextMenuVisible = false;
},
menuItemClicked(option) {
// 處理菜單選項(xiàng)點(diǎn)擊事件
console.log('Clicked:', option);
this.hideContextMenu();
}
},
mounted() {
// 監(jiān)聽點(diǎn)擊頁面其他部分,以隱藏右鍵菜單
window.addEventListener('click', this.hideContextMenu);
},
beforeDestroy() {
// 移除監(jiān)聽器,以防止內(nèi)存泄漏
window.removeEventListener('click', this.hideContextMenu);
}
};
CSS:
.right-clickable {
position: relative;
}
.context-menu {
position: absolute;
background-color: #fff;
border: 1px solid #ccc;
padding: 5px;
box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
z-index: 1000;
}
.context-menu ul {
list-style: none;
padding: 0;
margin: 0;
}
.context-menu li {
padding: 5px 10px;
cursor: pointer;
}
? ? ?這是一個(gè)簡(jiǎn)單的示例,展示了如何使用 contextmenu
指令來實(shí)現(xiàn)右鍵點(diǎn)擊事件和彈出自定義的右鍵菜單。在這個(gè)示例中,當(dāng)用戶右鍵點(diǎn)擊 "Right-click me" 文本時(shí),會(huì)顯示一個(gè)自定義的菜單。右鍵菜單將會(huì)在用戶點(diǎn)擊其他地方或選擇菜單項(xiàng)后隱藏。
運(yùn)行效果圖:文章來源:http://www.zghlxwxcb.cn/news/detail-722290.html
文章來源地址http://www.zghlxwxcb.cn/news/detail-722290.html
到了這里,關(guān)于Javascript 、Vue —— 禁止鼠標(biāo)右鍵點(diǎn)擊事件!的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!