Как я могу отключить <option>в <select>на основе его значения в JavaScript? - PullRequest
41 голосов
/ 28 января 2010

У меня есть <select> с числом <option> с.Каждый имеет уникальную ценность.Мне нужно отключить <option> с заданным определенным значением (не innerhtml).

У кого-нибудь есть идеи, как?

Ответы [ 7 ]

73 голосов
/ 28 января 2010

Чистый Javascript

При использовании чистого Javascript вам придется циклически просматривать каждую опцию и проверять ее значение отдельно.

// Get all options within <select id='foo'>...</select>
var op = document.getElementById("foo").getElementsByTagName("option");
for (var i = 0; i < op.length; i++) {
  // lowercase comparison for case-insensitivity
  (op[i].value.toLowerCase() == "stackoverflow") 
    ? op[i].disabled = true 
    : op[i].disabled = false ;
}

Без включения нецелевых элементов:

// Get all options within <select id='foo'>...</select>
var op = document.getElementById("foo").getElementsByTagName("option");
for (var i = 0; i < op.length; i++) {
  // lowercase comparison for case-insensitivity
  if (op[i].value.toLowerCase() == "stackoverflow") {
    op[i].disabled = true;
  }
}

JQuery

С помощью jQuery вы можете сделать это одной строкой:

$("option[value='stackoverflow']")
  .attr("disabled", "disabled")
  .siblings().removeAttr("disabled");

Без включения нецелевых элементов:

$("option[value='stackoverflow']").attr("disabled", "disabled");

Обратите внимание, что не без учета регистра. «StackOverflow» не будет равняться «stackoverflow». Чтобы получить нечувствительное к регистру совпадение, вам придется циклически перебирать каждое из них, преобразовывать значение в нижний регистр, а затем проверять это:

$("option").each(function(){
  if ($(this).val().toLowerCase() == "stackoverflow") {
    $(this).attr("disabled", "disabled").siblings().removeAttr("disabled");
  }
});

Без включения нецелевых элементов:

$("option").each(function(){
  if ($(this).val().toLowerCase() == "stackoverflow") {
    $(this).attr("disabled", "disabled");
  }
});
3 голосов
/ 23 марта 2015

Установите id для опции, затем используйте get element by id и отключите его, когда выбрано значение x

пример

<body>
      <select class="pull-right text-muted small" 
                 name="driveCapacity" id=driveCapacity onchange="checkRPM()">
      <option value="4000.0" id="4000">4TB</option>
      <option value="900.0" id="900">900GB</option>
      <option value="300.0" id ="300">300GB</option>
    </select>
    </body>
<script>
var perfType = document.getElementById("driveRPM").value;
if(perfType == "7200"){         
        document.getElementById("driveCapacity").value = "4000.0";
        document.getElementById("4000").disabled = false;           
    }else{          
        document.getElementById("4000").disabled = true;            
    }    
</script>
1 голос
/ 27 января 2016
var vals = new Array( 2, 3, 5, 8 );
select_disable_options('add_reklamaciq_reason',vals);
select_disable_options('add_reklamaciq_reason');

function select_disable_options(selectid,vals){
  var selected = false ;
  $('#'+selectid+' option').removeAttr('selected');
  $('#'+selectid+' option').each(function(i,elem){
       var elid = parseInt($(elem).attr('value'));
       if(vals){
           if(vals.indexOf(elid) != -1){
               $(elem).removeAttr('disabled');
               if(selected == false){
                   $(elem).attr('selected','selected');
                   selected = true ; 
               }
           }else{
               $(elem).attr('disabled','disabled'); 
           }
       }else{
            $(elem).removeAttr('disabled');
       }
  });   
}

Здесь с JQ .. если кто-нибудь ищет его

0 голосов
/ 28 апреля 2019

По некоторым причинам другие ответы неоправданно сложны, это легко сделать в одну строку в чистом JavaScript:

Array.prototype.find.call(selectElement.options, o => o.value === optionValue).disabled = true;

или

selectElement.querySelector('option[value="'+optionValue.replace(/["\\]/g, '\\$&')+'"]').disabled = true;

Производительность зависит от количества параметров (чем больше параметров, тем медленнее первый) и от того, можно ли пропустить , экранирующий (вызов replace) из второго. Также первый использует функции Array.find и стрелки, которые недоступны в IE11.

0 голосов
/ 31 декабря 2018
<select class="pets">
  <option>Cat</option>
  <option>Dog</option>
  <option>Horse</option> 
</select>


$(document).ready(function() {
  $('.pets').children().each(function(index, element) {
    if ($(element).text() == "Dog") {
      $(this).prop('disabled', true);
    }
  });
});

https://jsfiddle.net/sapereaude/z17wfj0s/

0 голосов
/ 14 мая 2018

Я также хотел бы дать вам идею отключить <option> с заданным определенным значением (not innerhtml). Я рекомендую это с jQuery, чтобы получить самый простой способ. Смотрите мой образец ниже.

HTML

Status:  
<div id="option">
   <select class="status">
      <option value="hand" selected>Hand</option>
      <option value="simple">Typed</option>
      <option value="printed">Printed</option>
   </select>
</div>

Javascript

Идея в том, как отключить опцию Printed, когда текущим Status является Hand

var status = $('#option').find('.status');//to get current the selected value
var op = status.find('option');//to get the elements for disable attribute
(status.val() == 'hand')? op[2].disabled = true: op[2].disabled = false;

Вы можете увидеть, как это работает здесь:

https://jsfiddle.net/chetabahana/f7ejxhnk/28/

0 голосов
/ 30 января 2013

Вы также можете использовать эту функцию,

function optionDisable(selectId, optionIndices)
{
    for (var idxCount=0; idxCount<optionIndices.length;idxCount++)
    {
        document.getElementById(selectId).children[optionIndices[idxCount]].disabled="disabled";
        document.getElementById(selectId).children[optionIndices[idxCount]].style.backgroundColor = '#ccc';
        document.getElementById(selectId).children[optionIndices[idxCount]].style.color = '#f00';
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...