选择项目后自定义jQuery selectmenu下拉按钮?

时间:2015-04-09 01:41:38

标签: javascript jquery css jquery-ui jquery-ui-selectmenu

我希望创建一个颜色下拉列表,其中每种颜色都是项目旁边的小方块。

有:

enter image description here

想要(大致):

enter image description here

This version (jsfiddle)适用于下拉项目本身,但我还希望按钮也能更新,以便在其旁边显示彩色方块。

$.widget("custom.coloriconselectmenu", $.ui.selectmenu, {  
  _renderItem: function (ul, item) {  
    var li = $("<li>", {text: item.label});  
    var bgColorStyle = 'background-color:' + item.element.attr("data-color");  
    var fullStyle = "float: left; width: 21px; height: 19px; margin-right: 7px;" + bgColorStyle;  
    $("<div>", {style: fullStyle}).appendTo(li);  
    return li.appendTo(ul);  
  }
});  

$("#selectId").coloriconselectmenu({icons: {button: "custom-button"}});

有没有一种方法可以修改值更新中的下拉按钮,以包含下拉列表中的颜色方块?

1 个答案:

答案 0 :(得分:1)

按如下所示修改您的代码,以便它响应change事件:

$( "#selectId" ).coloriconselectmenu({ 
    icons: { button: "custom-button" }, 
    change: function(event, ui){ 
        var selectedColor = $(this).find("option:selected").attr("data-color");
        //alert(selectedColor);
        var hiddenSelectMenuBtn = "#" + $(this).attr("id")+"-button .ui-selectmenu-text"
        //alert($(hiddenSelectMenuBtn).text());

        var fullStyle = "float: left; width: 21px; height: 19px; margin-right: 7px; background-color:" + selectedColor;  
        $("<span>", {style: fullStyle}).prependTo($(hiddenSelectMenuBtn));  
}); 

您需要选择“选择菜单文本”,这不容易通过函数或属性公开。

您可以在updated jsfiddle

中查看此操作