搜索

首页  >  问答  >  正文

需要一个 jquery 脚本,根据最终用户的当前选择从选择框中移动选定的选项

我有一个 HTML 页面,最终用户可以通过选择框元素对我们的项目进行排名。

请参阅小提琴来观看简单的演示:

https://jsfiddle.net/Balkanlii/ghecv1j8/1/

我想构建一个jquery脚本,在第二次选择相同排名的情况下(如果最终用户改变主意等),它会改变所选选项。所以:

我已经构建了一个可以成功用于此目的的查询,但是脚本因以下条件而损坏:

如何修复它?

另外,有没有比我的方法更好的方法,我想知道,因为我是如何做到的,它变得越来越复杂。

如有任何帮助,我们将不胜感激。

到目前为止我的 jQuery 脚本:

var previousValue = 0;
$("select[class='myclass']").on('focusin', function(){
     previousValue = $(this).val();
});

$("select[class='myclass']").on('change', function (event) { 
    var prevValue = parseInt(previousValue);
    var selectedValue = parseInt($(this).val());
    var selectedId = $(this).attr('id');

    $('#' + selectedId + " option").removeAttr("selected");
    $('#' + selectedId + " option[value=\""+selectedValue+"\"]").attr('selected', true);

    $("select[class='myclass']").each(function (index, element) { 
           var eval = parseInt($('#' + element.id).val());
            if (prevValue !== 0 && selectedValue !== 0) {
                if (eval >= selectedValue && (eval < prevValue) && element.id !== selectedId) {
                       var b = eval + 1;
                        if (b <= 3)
                            $('#' + element.id).prop('selectedIndex', b);
                        $('#' + element.id + " option").removeAttr("selected");
                        $('#' + element.id + " option[value=\"" + b + "\"]").attr('selected', true);

                }
                else if (eval <= selectedValue && (eval > prevValue) && element.id !== selectedId) {
                       var b = eval - 1;
                       $('#' + element.id).prop('selectedIndex', b);
                       $('#' + element.id + " option").removeAttr("selected");
                       $('#' + element.id + " option[value=\"" + b + "\"]").attr('selected', true);
                            }
                }
                else if (prevValue == 0) {
                            if (selectedValue > 0) {
                                if (eval >= selectedValue && element.id !== selectedId) {
                                    var b = eval + 1;
                                    if (b <= 3) {
                                        $('#' + element.id).prop('selectedIndex', b);

                                        $('#' + element.id + " option").removeAttr("selected");
                                        $('#' + element.id + " option[value=\"" + b + "\"]").attr('selected', true);
                                    }
                                }
                            }
                }
        });
 });

P粉170858678P粉170858678273 天前3741

全部回复(1)我来回复

  • P粉301523298

    P粉3015232982024-04-05 16:02:41

    您可以执行如下操作,禁用其他字段中选定的选项。这是它工作的屏幕录制...

    (function($) {
    
      const $all = $('select.myclass');
      
      $all.on('change input', function() {
    
        $all.find('option[disabled]').prop('disabled', false);
        
        $all.each(function() {
          const $this = $(this);
          const value = $this.val();
          
          $all.not($this).find(`option[value="${value}"]`)
            .prop('selected', false)
            .prop('disabled', !!parseInt(value));
        });
      });
    
    })(jQuery);
    sssccc
    Project 1
    
    Project 2
    Project 3

    回复
    0
  • 取消回复