我的网页上有动态创建的选择(下拉列表),这是由shell CGI脚本创建的网页:
while read line; do
textBoxValue=`printf "$line" | cut -d' ' -f1`
comboBoxValue=`printf "$line" | cut -d' ' -f2`
echo "
<div id="divId$start_id">
<input type="text" name="newTexdtBox$start_id" id="newTextBox" value='$textBoxValue' />
<select name="newComboBox$start_id" id="newComboBox" value="$comboBoxValue">
<option disabled>pls select</option>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
<option value="4">4</option>
<option value="5">5</option>
<option value="6">6</option>
<option value="7">7</option>
<option value="9">all</option>
</select>
<a href='javascript:void(0)' onclick='return removeThisElement($start_id)'>Remove This</a>
</div>
<a href='javascript:void(0)' onclick='return getSelects()'>getSelects</a>
"
start_id=$((start_id+1))
count=$((count + 1))
done < my_conf
每个Select对象都有自己的属性值= $ comboBoxValue。我想在加载页面时将此值属性设置为选中。建议的解决方案是(http://snipplr.com/view/67752/set-default-value-for-select-dropdown-lists-using-value-attribute/),但似乎不起作用,因为this.getAttribute(“value”)不返回任何内容。
如何使用value属性设置Select(下拉列表)的默认值?
答案 0 :(得分:1)
试
<select name="newComboBox$start_id" id="newComboBox" value="$comboBoxValue">
<option value="" selected='selected'>pls select</option>
<option value="1">1</option>
答案 1 :(得分:1)
如果你想用jQuery解决它
$(function(){
$('select[value]').each(function(){
$('option[value="' + $(this).attr('value') + '"]', this).prop('selected', true);
});
});
演示:Fiddle
但最佳解决方案是使用html标记本身来解决它。 (我不知道cgi脚本),但类似
<select name="newComboBox$start_id" id="newComboBox">
<option disabled>pls select</option>
<option #if ($comboBoxValue == 1) { selected="selected"} value="1">1</option>
<option #if ($comboBoxValue == 2) { selected="selected"} value="2">2</option>
<option #if ($comboBoxValue == 3) { selected="selected"} value="3">3</option>
....
</select>
答案 2 :(得分:0)
解决方案http://snipplr.com/view/67752/set-default-value-for-select-dropdown-lists-using-value-attribute/工作正常,我刚刚忘记了来自Shell脚本的渲染函数的符号(getAttribute(\“value \”))。
这很好(从CGI Shell脚本渲染时):
\$(document).ready(function() {
\$('select[value]').each(function(){
\$(this).val(this.getAttribute(\"value\"));
});
});