我的代码可以在IE中运行,但在Safari、Firefox和Opera中会崩溃。(惊喜)
document.getElementById("DropList").options.length=0;
经过搜索,我了解到它不喜欢的是长度=0。 我试过了……选项=null和var clear=0...长度=clear,结果相同。
我一次对多个对象这样做,所以我正在寻找一些轻量级的JS代码。
我的代码可以在IE中运行,但在Safari、Firefox和Opera中会崩溃。(惊喜)
document.getElementById("DropList").options.length=0;
经过搜索,我了解到它不喜欢的是长度=0。 我试过了……选项=null和var clear=0...长度=clear,结果相同。
我一次对多个对象这样做,所以我正在寻找一些轻量级的JS代码。
当前回答
注意,一个选择可以同时具有这两种情况 - optgroup & -选项集合 就像它的孩子一样。
So,
方法# 1
var selectElement = document.getElementById('myselectid');
selectElement.innerHTML = '';
方法# 2
var selectElement = document.getElementById('myselectid');
selectElement.textContent = '';
我测试过,两者都可以在Chrome上运行。 我喜欢简单的,老式的方法#1。
其他回答
这是一条很短的路:
document.getElementById('mySelect').innerText = null;
一行,没有for,没有JQuery,很简单。
这是一种现代的纯JavaScript
document.querySelectorAll('#selectId option').forEach(option => option.remove())
注意,一个选择可以同时具有这两种情况 - optgroup & -选项集合 就像它的孩子一样。
So,
方法# 1
var selectElement = document.getElementById('myselectid');
selectElement.innerHTML = '';
方法# 2
var selectElement = document.getElementById('myselectid');
selectElement.textContent = '';
我测试过,两者都可以在Chrome上运行。 我喜欢简单的,老式的方法#1。
可以使用以下命令清除所有元素。
var select = document.getElementById("DropList");
var length = select.options.length;
for (i = length-1; i >= 0; i--) {
select.options[i] = null;
}
使用PrototypeJS:
$('yourSelect').select('option').invoke('remove');