Контекстное меню на вложенном дочернем элементе также показывает родительское контекстное меню

У меня есть несколько элементов DOM с контекстными меню. Когда один элемент является дочерним для другого, и я вызываю контекстное меню внутреннего дочернего элемента, я также вижу контекстное меню от родительского элемента. Это реализовано с помощью плагина https://github.com/mar10/jquery-ui-contextmenu.

Есть ли способ настроить плагин так, чтобы родительское меню не отображалось, или мне придется обрабатывать все события нажатия вручную и фильтровать их, чтобы я показывал только то меню, которое мне нужно?

Ниже приведен мой код:

HTML:

    <!-- Add a child which will have a context menu -->
    <div class="outer-child" id="outer-child">
        Outer Child

        <!-- inner child with its own context menu -->
        <div class="inner-child" id="inner-child">
            Inner Child
        </div>
    </div>
</div>

CSS:

.outer-child {
    position: absolute;
    top: 0px;
    left: 0px;
    width: 200px;
    height: 200px;
    border: 1px solid red;
    background: green;
}
.inner-child {
    position: absolute;
    top: 50px;
    left: 50px;
    width: 100px;
    height: 100px;
    border: 1px solid blue;
    background: yellow;
}

JavaScript:

// create context menu on outer child
$("#outer-child").contextmenu({
    menu: [
        {title: "This is the Outer Menu", cmd: "outer-menu"}
        ],
    select: function(event, ui) {
        alert("select " + ui.cmd + " on " + ui.target.text());
    }
});


// create context menu on inner child
$('#inner-child').contextmenu({
    menu: [
        {title: "Inner Menu", cmd: "inner-menu"}
        ],
    select: function(event, ui) {
        alert("select " + ui.cmd + " on " + ui.target.text());
    }
});

Вы можете найти демоверсию jsfiddle здесь. (Щелкните правой кнопкой мыши на внутреннем блоке и увидите оба контекстных меню)

1 ответ

Вы можете решить эту проблему, позвонив event.stopPropagation() метод в beforeOpen событие дочернего элемента.

// create context menu on outer child
$("#outer-child").contextmenu({
  menu: [{
    title: "This is the Outer Menu",
    cmd: "outer-menu"
  }],
  select: function(event, ui) {
    alert("select " + ui.cmd + " on " + ui.target.text());
  },

});


// create context menu on inner child
$('#inner-child').contextmenu({
  beforeOpen: function(event, ui) {
    event.stopPropagation();
  },
  menu: [{
    title: "Inner Menu",
    cmd: "inner-menu"
  }],
  select: function(event, ui) {
    alert("select " + ui.cmd + " on " + ui.target.text());
  }
});
.outer-child {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 200px;
  height: 200px;
  border: 1px solid red;
  background: green;
}
.inner-child {
  position: absolute;
  top: 50px;
  left: 50px;
  width: 100px;
  height: 100px;
  border: 1px solid blue;
  background: yellow;
}
<link href="http://code.jquery.com/ui/1.9.2/themes/base/jquery-ui.css" rel="stylesheet" />
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="http://code.jquery.com/ui/1.9.2/jquery-ui.js"></script>
<script src="http://wwwendt.de/tech/demo/jquery-contextmenu/jquery.ui-contextmenu.js"></script>
<!-- Create an area to contain our editable components -->
<div class="container" id="container">
  <!-- Add a child which will have a context menu -->
  <div class="outer-child" id="outer-child">Outer Child
    <!-- inner child with its own context menu -->
    <div class="inner-child" id="inner-child">Inner Child</div>
  </div>
</div>

Другие вопросы по тегам