小码哥的IT人生

oncontextmenu 事件

JavaScript基础 2022-06-08 11:58:07小码哥的IT人生shichen

oncontextmenu 事件

实例

当用户右键单击带有上下文菜单的 <div> 元素时执行 JavaScript:

<div oncontextmenu="myFunction()" contextmenu="mymenu">

完整实例:

<!DOCTYPE html>
<html>
<head>
<style>
div {
  background: yellow;
  border: 1px solid black;
  padding: 10px;
}
</style>
</head>
<body>
<div oncontextmenu="myFunction()" contextmenu="mymenu">
<p>在此框中右键单击以查看上下文菜单!
<menu type="context" id="mymenu">
  <menuitem label="Refresh" onclick="window.location.reload();" icon="ico_reload.png"></menuitem>
  <menu label="Share on...">
  <menuitem label="Twitter" icon="ico_twitter.png" onclick="window.open('//twitter.com/intent/tweet?text=' + window.location.href);"></menuitem>
  <menuitem label="Facebook" icon="ico_facebook.png" onclick="window.open('//facebook.com/sharer/sharer.php?u=' + window.location.href);"></menuitem>
  </menu>
  <menuitem label="Email This Page" onclick="window.location='mailto:?body='+window.location.href;"></menuitem>
</menu>
</div>
<script>
function myFunction() {
  alert("You right-clicked inside the div!");
}
</script>
<p><b>注释:</b>contextmenu 属性仅适用于 Firefox!</p>
</body>
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

定义和用法

当用户右键单击某个元素以打开上下文菜单时,会发生 oncontextmenu 事件。

注释:虽然所有浏览器都支持 oncontextmenu 事件,但目前只有 Firefox 支持 contextmenu 属性

浏览器支持

事件 Chrome IE Firefox Safari Opera
oncontextmenu 支持 支持 支持 支持 支持

语法

在 HTML 中:

<element oncontextmenu="myScript">

完整实例:

<!DOCTYPE html>
<html>
<head>
<style>
div {
  background: yellow;
  border: 1px solid black;
  padding: 10px;
}
</style>
</head>
<body>
<p>本例演示如何将 "oncontextmenu" 事件分配给 div 元素。</p>
<div oncontextmenu="myFunction()" contextmenu="mymenu">
<p>在此框中右键单击以查看上下文菜单!
<menu type="context" id="mymenu">
  <menuitem label="Refresh" onclick="window.location.reload();" icon="ico_reload.png"></menuitem>
  <menu label="Share on...">
  <menuitem label="Twitter" icon="ico_twitter.png" onclick="window.open('//twitter.com/intent/tweet?text=' + window.location.href);"></menuitem>
  <menuitem label="Facebook" icon="ico_facebook.png" onclick="window.open('//facebook.com/sharer/sharer.php?u=' + window.location.href);"></menuitem>
  </menu>
  <menuitem label="Email This Page" onclick="window.location='mailto:?body='+window.location.href;"></menuitem>
</menu>
</div>
<p id="demo"></p>
<script>
function myFunction() {
  var x = document.getElementById("demo");
  x.innerHTML = "You right-clicked inside div!";
  x.style.fontSize = "30px";
}
</script>
<p><b>注释:</b>contextmenu 属性仅适用于 Firefox!</p>
</body>
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

在 JavaScript 中:

object.oncontextmenu = function(){myScript};

完整实例:

<!DOCTYPE html>
<html>
<head>
<style>
div {
  background: yellow;
  border: 1px solid black;
  padding: 10px;
}
</style>
</head>
<body>
<p>本例使用 HTML DOM 将 "oncontextmenu" 事件分配给 div 元素。</p>
<div id="myDIV" contextmenu="mymenu">
<p>在此框中右键单击以查看上下文菜单!
<menu type="context" id="mymenu">
  <menuitem label="Refresh" onclick="window.location.reload();" icon="ico_reload.png"></menuitem>
  <menu label="Share on...">
    <menuitem label="Twitter" icon="ico_twitter.png" onclick="window.open('//twitter.com/intent/tweet?text=' + window.location.href);"></menuitem>
    <menuitem label="Facebook" icon="ico_facebook.png" onclick="window.open('//facebook.com/sharer/sharer.php?u=' + window.location.href);"></menuitem>
  </menu>
  <menuitem label="Email This Page" onclick="window.location='mailto:?body='+window.location.href;"></menuitem>
</menu>
</div>
<p id="demo"></p>
<script>
document.getElementById("myDIV").oncontextmenu = function() {myFunction()};
function myFunction() {
  var x = document.getElementById("demo");
  x.innerHTML = "You right-clicked inside div!";
  x.style.fontSize = "30px";
}
</script>
<p><b>注释:</b>contextmenu 属性仅适用于 Firefox!</p>
</body>
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

在 JavaScript 中,使用 addEventListener() 方法:

object.addEventListener("contextmenu", myScript);

完整实例:

<!DOCTYPE html>
<html>
<head>
<style>
div {
  background: yellow;
  border: 1px solid black;
  padding: 10px;
}
</style>
</head>
<body>
<p>本例使用 addEventListener() 方法将 "contextmenu" 事件附加到 div 元素。</p>
<div id="myDIV" contextmenu="mymenu">
<p>在此框中右键单击以查看上下文菜单!
<menu type="context" id="mymenu">
  <menuitem label="Refresh" onclick="window.location.reload();" icon="ico_reload.png"></menuitem>
  <menu label="Share on...">
    <menuitem label="Twitter" icon="ico_twitter.png" onclick="window.open('//twitter.com/intent/tweet?text=' + window.location.href);"></menuitem>
    <menuitem label="Facebook" icon="ico_facebook.png" onclick="window.open('//facebook.com/sharer/sharer.php?u=' + window.location.href);"></menuitem>
  </menu>
  <menuitem label="Email This Page" onclick="window.location='mailto:?body='+window.location.href;"></menuitem>
</menu>
</div>
<p id="demo"></p>
<script>
document.getElementById("myDIV").addEventListener("contextmenu", myFunction);
function myFunction() {
  var x = document.getElementById("demo");
  x.innerHTML = "You right-clicked inside div!";
  x.style.fontSize = "30px";
}
</script>
<p><b>注释:</b>contextmenu 属性仅适用于 Firefox!</p>
</body>
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

注释:Internet Explorer 8 或更早的版本不支持 addEventListener() 方法

技术细节

冒泡: 支持
可取消: 支持
事件类型: MouseEvent
支持的 HTML 标签: 所有 HTML 元素
DOM 版本: Level 3 Events

版权所有 © 小码哥的IT人生
Copyright © phpcodeweb All Rights Reserved
ICP备案号:苏ICP备17019232号-2  

苏公网安备 32030202000762号

© 2021-2024