用于取消选择菜单中的项目的事件处理程序,其中启用了多个属性

时间:2011-06-14 12:11:22

标签: jquery-mobile select-menu

我正在使用一个选择菜单,可以进行多项选择。我有一个事件处理程序

 $("#idInventory").change(function () {
     $("#select option:selected").each(function () {
    });
});

在选择项目时调用。在这里,我收集了所选项目。但我还需要知道何时取消选择每个所选项目,以便我可以跟踪取消选择的内容,以便我可以跟踪用户现在取消选择已经选择的内容。

更新:取消选中某个项目时,我未触发此事件。

2 个答案:

答案 0 :(得分:1)

我认为这是你可能正在寻找的东西:

有点工作演示:

HTML

<div data-role="page" data-theme="b" id="home"> 
    <div data-role="content">

        <div data-role="fieldcontain"> 
            <label for="select-choice-9" class="select">Choose shipping method(s):</label> 
            <select name="select-choice-9" id="select-choice-9" multiple="multiple" data-native-menu="false"> 
                <option>Choose options</option> 
                <option value="standard">Standard: 7 day</option> 
                <option value="rush">Rush: 3 days</option> 
                <option value="express">Express: next day</option> 
                <option value="overnight">Overnight</option> 
            </select> 
        </div>

    </div>
</div>

JS

var values = {
    selected: [],
    unselected:[]
};

$("#select-choice-9").change(function () {
    values.selected   = [];
    values.unselected = [];

    $("#select-choice-9 option").each(function(){
        values[this.selected ? 'selected' : 'unselected'].push(this.value);
    });

    alert('Selected: '+values.selected+' Unselected: '+values.unselected);
});

更新:

$("#select-choice-9").change(function () {
    values.selected   = [];
    values.unselected = [];

    $("#select-choice-9 option").each(function(){
        values[this.selected ? 'selected' : 'unselected'].push(this.value);
    });

    alert('Selected: '+values.selected+' Unselected: '+values.unselected);
}).page();

更新#2

$("#select-choice-9").change(function () {
    values.selected   = [];
    values.unselected = [];

    $("#select-choice-9 option").each(function(){
        values[this.selected ? 'selected' : 'unselected'].push(this.value);
    });

    alert('Selected: '+values.selected+' Unselected: '+values.unselected);
}).checkboxradio("refresh");

答案 1 :(得分:0)

$("option").click(function(){
    if(this.selected)
      //do what you want to do
});