使用 javascript 禁用引导选择选项

Posted

技术标签:

【中文标题】使用 javascript 禁用引导选择选项【英文标题】:disable bootstrap select option using javascript 【发布时间】:2017-07-13 08:08:55 【问题描述】:

我尝试使用 javascript 禁用我的特定引导选择选项。

我知道如何禁用“正常选择选项”,但是当使用引导选择时它不起作用(它被禁用/灰色但我仍然可以选择它) 这里jsfidle

<select name="dropdownBranch" id="dropdownBranch" class="selectpicker" data-live-search="true">
  <option value="0">Choose Number</option>
    <option value="1">1</option>
  <option value="2">2</option>
  <option value="3">3</option>
  <option value="4">4</option>
</select>
<select id="pureDropDown">
  <option value="0">Choose Number</option>
    <option value="1">1</option>
  <option value="2">2</option>
  <option value="3">3</option>
  <option value="4">4</option>
</select>
<button onclick="disableDropdown()">disable</button>



function disableDropdown()
var selectobject;
selectobject=document.getElementById("dropdownBranch").getElementsByTagName("option");
    selectobject[3].disabled=true;

selectobject=document.getElementById("pureDropDown").getElementsByTagName("option");
    for(z=0;z<selectobject.length;z++)
        selectobject[z].disabled=true;
        


我也尝试删除特定选项,但发生了同样的情况(在正常下拉菜单上工作,但在引导选择上不起作用)

【问题讨论】:

【参考方案1】:

如here 所述,您需要在更改选项的禁用属性后重新呈现选择选择器。

这应该可以解决问题:(JSFiddle)

function disableDropdown()
    var selectobject;
    selectobject = document.getElementById("dropdownBranch").getElementsByTagName("option");
    selectobject[3].disabled = true;
    $('#dropdownBranch').selectpicker('render');

【讨论】:

谢谢,这是工作,但这不适用于使用此patosai.com/projects/tree-multiselect 任何想法的树选择? $('#dropdownBranch').selectpicker('refresh'); 对于 bootstrap-selectPicker 的更新版本要好得多【参考方案2】:

使用 jQuery

$("#dropdownBranch").attr("disabled", "disabled");

或纯javascript:

function disableDropdown()
    document.getElementById("dropdownBranch").setAttribute("disabled", "disabled");

JSFiddle

【讨论】:

我想要的是禁用特定的选择选项,而不是禁用选择(这将禁用所有选择选项) 哦,在这种情况下,请尝试添加此代码:selectobject=document.getElementById("dropdownBranch").getElementsByTagName("option"); selectobject[3].setAttribute("disabled");,然后再调用$('#dropdownBranch').selectpicker();【参考方案3】:

如上所述使用render 不再有效。正如他们所写的Docs refresh 是更改选项后使用的方法。

要使用 JavaScript 以编程方式更新选择,首先要操作 选择,然后使用刷新方法更新 UI 以匹配 新状态。这在删除或添加选项时是必要的,或者当 通过 JavaScript 禁用/启用选择。

function disableDropdown()
    var selectobject;
    selectobject = document.getElementById("dropdownBranch").getElementsByTagName("option");
    selectobject[3].disabled = true;
    $('#dropdownBranch').selectpicker('refresh');

【讨论】:

【参考方案4】:

试试这个

function disableDropdown()
  var selectobject;
  selectobject=document.getElementById("dropdownBranch");
  selectobject.options[3].disabled=true;

  selectobject=document.getElementById("pureDropDown").getElementsByTagName("option");
for(z=0;z<selectobject.length;z++)
    selectobject[z].disabled=true;

【讨论】:

它不起作用,(这行错误我按下 selectobject.options[3].disabled=true;)【参考方案5】:

哟。你不就是 $.("selectedSelect").css("disabled", "disabled");

好的。我为我的努力不足而道歉。我意识到我的回答是轻率的,所以我选择了更多的努力。编辑:

这是我在你的 jsfiddle 上遇到的。如果我使用 .css、.val、.prop 或 .attr,我会收到错误消息。这让我觉得要么 jquery 对我来说在 jsfiddle 上不能正常工作,要么我做错了什么。

我挖得更深了。我看了一下html。在 jsfiddle 中,在 select 标记上方创建了一个引导组合框。我编辑了值为 3 的组合框 li 以使类“禁用”,并获得了所需的结果。

这使我得到了这段代码:

function disableDropdown()
    var selectobject, optionList;
    selectobject=document.getElementById("dropdownBranch")
    .getElementsByTagName("option");
    selectobject = $("li");
    selectobject[3].addClass("disabled");


    selectobject=document.getElementById("pureDropDown")
    .getElementsByTagName("option");
    for(z=0;z<selectobject.length;z++)
        selectobject[z].disabled=true;
    


您需要做的是访问引导创建的元素,并修改它以禁用该类。 Bootstrap 应该负责其余的工作。我相信你可以在自己的环境中做到这一点,但是 jsfiddle 很烦人,所以我不会继续研究这个。

【讨论】:

【参考方案6】:

这是一个完整的“Jquery”版本:

  var your_value = 2;
  $('#userSelect').val('').change();
  $(`#userSelect option[value='$your_value']`).prop('disabled', true);
  $('#userSelect').selectpicker('refresh');

【讨论】:

以上是关于使用 javascript 禁用引导选择选项的主要内容,如果未能解决你的问题,请参考以下文章

引导工具提示应在更改选择框上启用

如何动态生成日期选择器引导日期禁用

在引导日期时间选择器中禁用时间

如果为空选择选项,则单击按钮时显示模式引导

引导程序:无法/禁用 <a> 使用 javascript 的链接引导程序

更改选项卡后,从链接禁用引导程序打开选项卡