Javascript для выбора нескольких опций
У меня есть форма с полем выбора, который позволяет несколько вариантов. После сохранения этих параметров пользователь сохраняет их в таблице базы данных.
Затем я могу прочитать эту таблицу базы данных, чтобы снова выбрать параметры, которые они выбрали. Мне нужно уметь извлекать эти данные из базы данных, помещать их в массив, а затем выбирать опции в этом окне выбора, когда они переходят к "Редактировать" свои параметры.
Чтение данных в массиве прекрасное, и я знаю, как сделать одну опцию, выбранную в поле выбора, однако я не уверен, как обрабатывать несколько параметров, выбранных в javascript.
Может кто-нибудь помочь мне разобраться в javascript, который требуется для этого?
Ответы
Ответ 1
Чистое решение javascript
<select id="choice" multiple="multiple">
<option value="1">One</option>
<option value="2">two</option>
<option value="3">three</option>
</select>
<script type="text/javascript">
var optionsToSelect = ['One', 'three'];
var select = document.getElementById( 'choice' );
for ( var i = 0, l = select.options.length, o; i < l; i++ )
{
o = select.options[i];
if ( optionsToSelect.indexOf( o.text ) != -1 )
{
o.selected = true;
}
}
</script>
Хотя я согласен, это должно быть сделано на стороне сервера.
Ответ 2
Этот тип вещей должен выполняться на стороне сервера, чтобы ограничить количество ресурсов, используемых на клиенте для таких тривиальных задач. Если вы хотите сделать это в интерфейсе, я бы посоветовал вам использовать что-то вроде underscore.js, чтобы сохранить код чистый и краткий:
var values = ["Red", "Green"],
colors = document.getElementById("colors");
_.each(colors.options, function (option) {
option.selected = ~_.indexOf(values, option.text);
});
Если вы используете jQuery, это может быть еще более кратким:
var values = ["Red", "Green"];
$("#colors option").prop("selected", function () {
return ~$.inArray(this.text, values);
});
Если бы вы сделали это без инструмента, такого как underscore.js или jQuery, у вас было бы немного больше, чтобы писать, и может показаться, что это немного сложнее:
var color, i, j,
values = ["Red", "Green"],
options = document.getElementById("colors").options;
for ( i = 0; i < values.length; i++ ) {
for ( j = 0, color = values[i]; j < options.length; j++ ) {
options[j].selected = options[j].selected || color === options[j].text;
}
}
Ответ 3
Вы можете получить доступ к массиву опций выбранного объекта, перейдя в document.getElementById("cars").options
, где "cars" - это выбранный объект.
После этого вы можете вызвать option[i].setAttribute('selected', 'selected');
, чтобы выбрать параметр.
Я согласен с каждым, что вам лучше делать эту серверную часть.
Ответ 4
<script language="JavaScript" type="text/javascript">
<!--
function loopSelected()
{
var txtSelectedValuesObj = document.getElementById('txtSelectedValues');
var selectedArray = new Array();
var selObj = document.getElementById('selSeaShells');
var i;
var count = 0;
for (i=0; i<selObj.options.length; i++) {
if (selObj.options[i].selected) {
selectedArray[count] = selObj.options[i].value;
count++;
}
}
txtSelectedValuesObj.value = selectedArray;
}
function openInNewWindow(frm)
{
// open a blank window
var aWindow = window.open('', 'Tutorial004NewWindow',
'scrollbars=yes,menubar=yes,resizable=yes,toolbar=no,width=400,height=400');
// set the target to the blank window
frm.target = 'Tutorial004NewWindow';
// submit
frm.submit();
}
//-->
</script>
The HTML
<form action="tutorial004_nw.html" method="get">
<table border="1" cellpadding="10" cellspacing="0">
<tr>
<td valign="top">
<input type="button" value="Submit" onclick="openInNewWindow(this.form);" />
<input type="button" value="Loop Selected" onclick="loopSelected();" />
<br />
<select name="selSea" id="selSeaShells" size="5" multiple="multiple">
<option value="val0" selected>sea zero</option>
<option value="val1">sea one</option>
<option value="val2">sea two</option>
<option value="val3">sea three</option>
<option value="val4">sea four</option>
</select>
</td>
<td valign="top">
<input type="text" id="txtSelectedValues" />
selected array
</td>
</tr>
</table>
</form>
Ответ 5
Основываясь на ответе @Peter Baley, я создал более общую функцию:
@objectId: HTML object ID
@values: can be a string or an array. String is less "secure" (should not contain repeated value).
function checkMultiValues(objectId, values){
selectMultiObject=document.getElementById(objectId);
for ( var i = 0, l = selectMultiObject.options.length, o; i < l; i++ )
{
o = selectMultiObject.options[i];
if ( values.indexOf( o.value ) != -1 )
{
o.selected = true;
} else {
o.selected = false;
}
}
}
Пример: checkMultiValues('thisMultiHTMLObject','a,b,c,d');