Onmousedown 不允许我点击链接

时间:2021-05-18 09:18:38

标签: javascript html

我尝试在右键单击时构建上下文菜单,它运行良好,除了一件事。在我的 li 项目中,我有一些链接 (href)。 但是,如果我单击这些链接,上下文菜单不会跟随 href,而只是关闭上下文菜单。

我做错了什么,但我看不到错误:

我的实际代码:


 const menu = document.querySelector('.menu');
  
  function showMenu(x, y) {
    menu.style.left = x + 'px';
    menu.style.top = y + 'px';
    menu.classList.add('menu-show');
  }

  function hideMenu() {
    menu.classList.remove('menu-show');
  }

  function onContextMenu(e) {
    e.preventDefault();
    showMenu(e.pageX, e.pageY);
    document.addEventListener('mousedown', onMouseDown, false);
  }

  function onMouseDown(e) {
    hideMenu();
    document.removeEventListener('mousedown', onMouseDown);
  }

  document.addEventListener('contextmenu', onContextMenu, false);
});

HTML:


<ul class="menu">
    <li class="menu-item">
        <a href="https://flarum.it" class="menu-btn">
            <i class="fa fa-folder-open"></i>
            <span class="menu-text">Open</span>
        </a>
    </li>
</ul>

1 个答案:

答案 0 :(得分:1)

点击链接事件与 onmouseup 事件一起发生。您已经使用 onmousedown 使这个过程变得不可能。


您所要做的就是侦听 mouseup 事件而不是 mousedown 事件,并且可能将 "onMouseDown" 函数的名称更改为 "onMouseUp"

document.addEventListener('mouseup', onMouseUp, false);

示例代码片段

var menu = document.querySelector('.menu');

function showMenu(x, y){
    menu.style.left = x + 'px';
    menu.style.top = y + 'px';
    menu.classList.add('menu-show');
}

function hideMenu(){
    menu.classList.remove('menu-show');
}

function onContextMenu(e){
    e.preventDefault();
    showMenu(e.pageX, e.pageY);
    document.addEventListener('mouseup', onMouseUp, false);
}

function onMouseUp(e){
    hideMenu();
    document.removeEventListener('mouseup', onMouseUp);
}

document.addEventListener('contextmenu', onContextMenu, false);
/* Page */

html {
    width: 100%;
    height: 100%;
    background: radial-gradient(circle, #fff 0%, #a6b9c1 100%) no-repeat;
}

.container {
    position: absolute;
    top: 20%;
    left: 0;
    width: 100%;
    margin: auto;
    text-align: center;
}

h1,
h2 {
    color: #555;
}

/* Menu */

.menu {
    position: absolute;
    width: 200px;
    padding: 2px;
    margin: 0;
    border: 1px solid #bbb;
    background: #eee;
    background: linear-gradient(to bottom, #fff 0%, #e5e5e5 100px, #e5e5e5 100%);
    z-index: 100;
    border-radius: 3px;
    box-shadow: 1px 1px 4px rgba(0,0,0,.2);
    opacity: 0;
    transform: translate(0, 15px) scale(.95);
    transition: transform 0.1s ease-out, opacity 0.1s ease-out;
    pointer-events: none;
}

.menu-item {
    display: block;
    position: relative;
    margin: 0;
    padding: 0;
    white-space: nowrap;
}

.menu-btn { 
    display: block;
    color: #444;
    font-family: 'Roboto', sans-serif;
    font-size: 13px;
    cursor: pointer;
    border: 1px solid transparent;
    white-space: nowrap;
    padding: 6px 8px;
    border-radius: 3px;
}

button.menu-btn {
    background: none;
    line-height: normal;
    overflow: visible;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    width: 100%;
    text-align: left;
}

a.menu-btn {
    outline: 0 none;
    text-decoration: none;
}

.menu-text {
    margin-left: 25px;
}

.menu-btn .fa {
    position: absolute;
    left: 8px;
    top: 50%;
    transform: translateY(-50%);
}

.menu-item:hover > .menu-btn { 
    color: #fff; 
    outline: none; 
    background-color: #2E3940;
    background: linear-gradient(to bottom, #5D6D79, #2E3940);
    border: 1px solid #2E3940;
}

.menu-item-disabled {
    opacity: .5;
    pointer-events: none;
}

.menu-item-disabled .menu-btn {
    cursor: default;
}

.menu-separator {
    display:block;
    margin: 7px 5px;
    height:1px;
    border-bottom: 1px solid #fff;
    background-color: #aaa;
}

.menu-item-submenu::after {
    content: "";
    position: absolute;
    right: 6px;
    top: 50%;
    transform: translateY(-50%);
    border: 5px solid transparent;
    border-left-color: #808080; 
}

.menu-item-submenu:hover::after {
    border-left-color: #fff;
}

.menu .menu {
    top: 4px;
    left: 99%;
}

.menu-show,
.menu-item:hover > .menu {
    opacity: 1;
    transform: translate(0, 0) scale(1);
    pointer-events: auto;
}

.menu-item:hover > .menu {
    transition-delay: 300ms;
}
<ul class="menu">
    <li class="menu-item">
        <a href="https://google.com" class="menu-btn">
            <i class="fa fa-folder-open"></i>
            <span class="menu-text">Open</span>
        </a>
    </li>
</ul>