Как получить последний выбранный вариант из мультиселекции? - PullRequest
10 голосов
/ 16 ноября 2011

Я ищу способ получить последний выбранный пользователем вариант в форме множественного выбора, используя jQuery.

Я ищу не последний элемент в списке, а последний элемент, на который нажал пользователь.

Ответы [ 3 ]

6 голосов
/ 16 ноября 2011

как то так

var lastSelected = null;
$('.multiSelectOptions').click(function(){
    lastSelected = this.value;
});
1 голос
/ 09 октября 2016

Использование this.value, как в ответе выше, завершается неудачно, когда пользователь нажал Ctrl + и выбрал несколько элементов - он возвращает значение первого выбора в списке, даже если это был не последний щелчок.Попробуйте это:

var previouslySelected = [];
$("#myMultiselect").change (function() {
    // Get newly selected elements
    var currentlySelected = $(this).val();
    var newSelections = currentlySelected.filter(function (element) {
        return previouslySelected.indexOf(element) == -1;
    });
    previouslySelected = currentlySelected;

    if (newSelections.length) {
        // If there are multiple new selections, we'll take the last in the list
        var lastSelected = newSelections.reverse()[0];
    }
});
0 голосов
/ 12 марта 2018

В основном вам нужно поддерживать стек, чтобы отслеживать последний выбранный элемент.Я написал эту функцию для обновления моего стека.

var determineLastSelectedReportNumber = function (selectedReportNumbers, oldSelectedReportNumbers) {
    var newlyAddedReportNumbers = 
    selectedReportNumbers.filter(function (n) {
        return oldSelectedReportNumbers.indexOf(n) == -1;
    });

    var removedReportNumbers = 
    oldSelectedReportNumbers.filter(function (n) {
        return selectedNumberArray.indexOf(n) == -1;
    });

    //Remove the removed reportNumbers from the stack.
    if (removedReportNumbers.length > 0) {                        
        removedReportNumbers.forEach(function (removedReportNumber) {
            for (var i = 0; i < selectedNumbersStack.length; i++) {
                if (selectedNumbersStack[i].toString() === removedReportNumber.toString()) {
                    selectedNumbersStack.splice(i, 1);
                    break;
                }
            }
        });
    }

    //Add the added reportnumbers to the stack. Push();
    if (newlyAddedReportNumbers.length > 0) {
        selectedNumbersStack.push(newlyAddedReportNumbers);
    }

    //Set the last selected from top of the stack. Peek();
    var lastSelectedReportNumber = "";
    if(selectedNumbersStack.length > 0){
        lastSelectedReportNumber = selectedNumbersStack[selectedNumbersStack.length -1];
    }

    return lastSelectedReportNumber;
}

И это моя реализация onChange:

var reportNumberChanged = function () {
    var $reportNumber = $(this);
    var selectedNumber = $reportNumber.val();

    oldSelectedNumberArray = selectedNumberArray;
    selectedNumberArray = jQuery.makeArray(selectedNumber);


    var lastSelectedReportNumber = determineLastSelectedReportNumber(selectedNumberArray, oldSelectedNumberArray);
    $("#TheLastSelectedReportNumber").val(lastSelectedReportNumber);        
    resetDelayRetrieveReportInfo();
}

Я мог бы также показать вам мой полный код:

var selectedNumberArray = jQuery.makeArray($('#SelectedReportNumbers').val());
//Initial selectedNumbersStack.
var selectedNumbersStack = selectedNumberArray;

var counterInitialValue = 3;
var counter = counterInitialValue;
var counterInterval = -1;

function delayRetrieveReportInfo() {
    counter--;
    if (counter === 0) {
        retrieveReportInfo($("#TheLastSelectedReportNumber").val());
        clearInterval(counterInterval);
    }
}

function resetDelayRetrieveReportInfo() {
    clearInterval(counterInterval); //The previous interval is cancelled.
    counter = counterInitialValue;
    counterInterval = setInterval(function () { delayRetrieveReportInfo() }, 1000);
}

И это соединение множественного выбора:

// Hookup function to change events of select lists
$('#SelectedReportNumbers').change(reportNumberChanged);

Вы можете повторно использовать часть моего кода для создания собственной реализации 'lastSelected'.

...