我是JavaScript中createElement
属性的新手。我需要从MySQL查询创建一个下拉菜单。我已经从MySQL查询创建了一个PHP数组,如下所示:
<?
$vendorInformation=mysql_query("SELECT * FROM `vendor`",$con);
$row=array();
while($v=mysql_fetch_assoc($vendorInformation))
{
$row[]= $v['id'];
$row[]= $v['name'];
}
$row=json_encode($row);
echo $row;
//OUTPUT: ["1","Cisco","2","Juniper","3","Opengear"]
?>
然后我编写了JavaScript代码:
<script>
var inputs = 1;
var v_array = <?=$row;?>;
//OUTPUT for v_array: 1,Cisco,2,Juniper,3,Opengear
var inp3 = document.createElement('SELECT');
var o=document.createElement("option");
inp3.setAttribute("id","v"+(inputs));
for (var i = 0; i < v_array.length; i++)
{
var o=document.createElement("option");
o.setAttribute("name","red");
o.setAttribute("value","me");
o.innerHTML=name;
inp3.appendChild(o);
}
</script>
我不确定如何完成此代码。
根据数组的输出,选项值应为1,2,3,值应为Cisco,Juniper,Opengear(分别)。
答案 0 :(得分:1)
最好在PHP中使用这种格式:
while($v = mysql_fetch_assoc($vendorInformation)) {
$row[] = array(
"id"=>$v['id'],
"name"=>$v['name']
);
}
然后,在您的JavaScript中,您可以执行此操作:
var inp3 = document.createElement('select'),
l = v_array.length, i;
for( i=0; i<l; i++) {
inp3.options[i] = new Option(v_array[i].name,v_array[i].id);
}