Fork me on GitHub

jQuery contextMenu

Demo: Adding new Context Menu Triggers

jQuery.contextMenu allows you to define a <menu> before the trigger elements are available

Example code: Adding new Context Menu Triggers


$(function(){
    // add new trigger
    $('#add-trigger').on('click', function(e) {
        $('<div class="context-menu-one box menu-injected">'
            + 'right click me <em>(injected)</em>'
            + '</div>').insertBefore(this);

        // not need for re-initializing $.contextMenu here :)
    });
    
    $.contextMenu({
        selector: '.context-menu-one', 
        callback: function(key, options) {
            var m = "clicked: " + key;
            window.console && console.log(m) || alert(m); 
        },
        items: {
            "edit": {name: "Edit", icon: "edit"},
            "cut": {name: "Cut", icon: "cut"},
            "copy": {name: "Copy", icon: "copy"},
            "paste": {name: "Paste", icon: "paste"},
            "delete": {name: "Delete", icon: "delete"},
            "sep1": "---------",
            "quit": {name: "Quit", icon: "quit"}
        }
    });
});
    

Example HTML: Adding new Context Menu Triggers

<div class="context-menu-one box menu-1">
    <strong>right click me</strong>
</div><button type="button" id="add-trigger">add new trigger</button>

jQuery Context Menu Demo Gallery