1

我需要使用jQuery UI Menu做一个多下拉菜单。在此之前,我们为此目的使用了jQuery UI Selectmenu 。

Selectmenu 基于select,其中可以使用一种val()方法来获取/设置选择值。现在菜单基于 ul/li,所以我没有这样的选项。

所以我需要以某种方式模仿以下行为:

someMenu.menu();
//....                
someMenu.val(someValue);
someMenu.menu("refresh");

我尝试扩展菜单小部件并添加一些方法,例如:

 $.widget("market.multiDropdownMenu",$.ui.menu, {
    //....
    getSelectedItem: function () {
        return this.active;             
    },

    setSelectedItem: function(elem){
        var elem = this.element.find(elem).first();
        if (elem) {
            this.active = elem;
            this.focus('focus', elem);
            this.element.find('.ui-menu-item.selected').removeClass('selected');
            this.getSelectedItem().addClass('selected');  
        }
    },
    //....
}

然后像这样使用它:

// for getter
var elem = someMenu.multiDropdownMenu("getSelectedItem"); // getting null
// and for setter
var newElem = ...
someMenu.multiDropdownMenu("setSelectedItem", newElem);
someMenu.multiDropdownMenu("refresh");

但是在设置了一些值并尝试在下次active字段为null.

我也尝试elem.trigger('click');改用焦点事件但没有成功。

4

1 回答 1

3

我并不完全清楚你想在这里做什么,但可能你可以做的是为菜单中选择的任何元素设置一个类。然后,如果您想知道哪个被选中,您只需使用该类。

选择集:

$( "#menu" ).menu({
    select: function(event, ui) {
        $('.selectedItem').removeClass('selectedItem');
        $(event.currentTarget).addClass('selectedItem');

    }
});

获取选定的值:

$('.selectedItem').text();

小提琴

于 2015-10-19T13:06:25.770 回答