0

如何在 jQuery Mobile 多选中触发 click 事件?

我正在尝试在选择选项中添加一个关闭按钮,因为我不觉得 (X) 关闭按钮是直截了当的。这个话题在这里讨论(http://stackoverflow.com/questions/10004719/jquery-mobile-multi-select-box),答案是:

您可以添加 Close 作为选项,然后在单击时触发对话框关闭方法

不讨论如何触发点击事件。我尝试了以下方法:

$("#selectmenu").change(function() {
alert('Changed!!');});

$(document).delegate('.ui-selectmenu-screen', 'click', function () {
alert('changed');
}).delegate('.ui-selectmenu .ui-btn-inner', 'click', function (event) {
alert('changed2');});

$('#selectmenu').on('change', function () {
alert('changed');});

$('#selectmenu').live('change', function () {
alert('changed');});

$('#pageName').on('click', '.ui-selectmenu-list > li', function () {
alert('changed');});

$("#selectmenu").live( "click", function(event, ui) {
alert('changed');});

$("#selectmenu").bind( "click", function(event, ui) {
alert('changed');});
4

1 回答 1

0

您将使用此处找到的 $.selectmenu() 方法并像这样绑定到change事件:

HTML

<div data-role="fieldcontain">
    <select name="selectmenu" id="selectmenu" multiple="multiple">
        <option value="value1">Value 1</option>
        <option value="value2">Value 2</option>
        <option value="value3">Value 3</option>
        <option value="close">Close</option>
    </select>
</div>

关闭选择菜单

$(document).delegate('#selectmenu', 'change', function(){
    var str = $('#selectmenu option:selected').val(); // Get Value of Option

    if (str == 'close'){
        $('#selectmenu').selectmenu('close');
    }
});

添加价值

function addValues($el){
    var total = 0;
    $('option', $el).each(function(){
        var value = parseInt($(this).val());
            value = (isNaN(value-0)) ? 0 : parseInt(value); // Defaults Value to 0 if NaN

        total += value;
    });
    return total;
}

用于添加值的 JSFiddle

我希望这有帮助!

于 2012-09-04T22:02:06.053 回答