Javascriptまたはmootoolsを使用してhtml選択リストのオプション配列を変更する方法はありますか?
オプションセット全体を新しいものに置き換える必要があります。私のajax応答では、新しいHTMLオプションで満たされた配列を受け取りますので、古いリストを空にして、次のように新しい値を追加しようとします
$('element').options.length=0;
for (i=0; i<newSet.length; i++)
{
$('element').options[i]=newSet[i];
}
上記のコードでは、ループ内の行でキャッチされない例外が発生します。
キャッチされない例外:[例外... "予期しないエラー" nsresult: "0x8000ffff(NS_ERROR_UNEXPECTED)"場所: "JSフレーム
私のために働いたものを追加するだけです:
/* get new options from json*/
var new_options = response.options;
/* Remove all options from the select list */
$('idresource').empty();
/* Insert the new ones from the array above */
for (var key in new_options)
{
var opt = document.createElement('option');
opt.text = new_options[key];
opt.value = key;
$('idresource').add(opt, null);
}
var new_options = ['Option 1', 'Option 2', 'Option 3'];
/* Remove all options from the select list */
$('yourSelectList').empty();
/* Insert the new ones from the array above */
$each(new_options, function(value) {
new Element('option')
.set('text', value)
.inject($('yourSelectList'));
});
HTML
<select class="element">
<option value="1">One</option>
<option value="2">Two</option>
<option value="3">Three</option>
</select>
<button><<<</button>
<select class="newSel">
<option value="11">NewOne</option>
<option value="22">NewTwo</option>
<option value="33">NewThree</option>
</select>
Javascript
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>
$("button").click(function(){
var oldSel = $('.element').get(0);
while (oldSel.options.length > 0) {
oldSel.remove(oldSel.options.length - 1);
}
var newSel = $('.newSel').get(0);
for (i = 0; i < newSel.length; i++)
{
var opt = document.createElement('option');
opt.text = newSel.options[i].text;
opt.value = newSel.options[i].value;
oldSel.add(opt, null);
}
})
var newOptionsHtml = "<option value='2'>New Option 1</option><option value='3'>New Option 2</option>";
$("#test").html(newOptionsHtml);
Selectオブジェクトでremove
およびadd
を使用してDOMを操作します。詳細については http://www.w3schools.com/jsref/dom_obj_select.asp を参照してください。
一部の選択要素に新しいオプションを追加するには、次のコードを記述しました。
/**
Adds an option to a select(HTML) element.
@param {HTMLElement} select_element The select eletement.
@param {string} option_str The text of the option.
@param {Object} [option_attr] The options to be copied into the option element created.
@returns {HTMLElement} The option element created.
*/
function addOptionStrToSelectElement(select_element, option_str, option_attr){
if (!option_attr) option_attr = {};
var doc = select_element.ownerDocument;
var opt = doc.createElement("option");
opt.text = option_str;
for (var prop in option_attr){
if (option_attr.hasOwnProperty(prop)){
opt[prop] = option_attr[prop];
}
}
doc = null;
if (select_element.add.length === 2){
select_element.add(opt, null); // standards compliant
} else{
select_element.add(opt); // IE only
}
return opt;
}
バニラJSソリューション
var arrOptions = [];
arrOptions.Push("<option value='' selected>Select from List...</option>");
arrOptions.Push("<option value='Trust Deposit'>Trust Deposit</option>");
arrOptions.Push("<option value='Operating Deposit'>Operating Deposit</option>");
document.getElementById("selectInput").innerHTML = arrOptions.join();
すでにオプションのセットがある場合
var arrOptions = [];
var arrOptionsCollection = document.getElementById("check_typeInput").options;
for (var i=0, n = arrOptionsCollection.length; i < n; i++) { // looping over the options
if (arrOptionsCollection[i].value) {
arrOptions.Push("<option value='" + arrOptionsCollection[i].value + "'>" + arrOptionsCollection[i].text + "</option>");
}
}
arrOptions.Push("<option value='Trust Deposit'>Trust Deposit</option>");
arrOptions.Push("<option value='Operating Deposit'>Operating Deposit</option>");
document.getElementById("selectInput").innerHTML = arrOptions.join();