我正在建立一个界面,第一个下拉列表中的选项决定了后续6个下拉列表中可用的选项。
每个下拉列表都会从表格中获取其值和显示名称:
$arr = array();
$rs = mysql_query("SELECT * FROM sn_roles");
while($obj = mysql_fetch_object($rs)) {
$arr[] = $obj;
}
$response = '{"roles":'.json_encode($arr).'}';
echo $response;
获取json编码。
我想要做的是从多个表中选择id和name,并为每个表获取一个json对象集合。
答案 0 :(得分:1)
你需要为每个下拉选项使用ajax并将特定表的返回json对象存储到javascript对象
<select name="selector1" id="selector1" onChange="getoptions();"
<option value="1">--Select--</option>
<option value="2">option1</option>
<option value="3">option2</option>
<option value="4">option3</option>
</select>
<select name="selector2" id="selector2">
</select>
<select name="selector3" id="selector3">
</select>
和下拉列表的javascript代码就像
function getoptions(){
$('#selector2').html('<option value="">--Select--</option>');
$('#selector3').html('<option value="">--Select--</option>');
var selector1 = $('#selector1').val();
jQuery.get('getdropAjax.php', {'_action_':'GetDropValue', Selector1val : selector1 }, function(r) {
for (var i in r.forselector2)
{
$('#selector2').append('<option value="'+i+'">'+r.forselector2[i]+'</option>');
}
for (var i in r.forselector3)
{
$('#selector3').append('<option value="'+i+'">'+r.forselector3[i]+'</option>');
}
}, 'json');
}
你的php代码就像
<?php
$data = array();
switch ( $_GET['_action_'] ){
case 'GetDropValue':
$arr1 = array();
$rs = mysql_query("SELECT `colname` FROM sn_roles");
while($obj = mysql_fetch_object($rs)) {
$arr1[] = $obj->colname;
}
$data['forselector2'] = $arr1;
$arr2 = array();
$rs = mysql_query("SELECT `colname` FROM table2");
while($obj = mysql_fetch_object($rs)) {
$arr2[] = $obj->colname;
}
$data['forselector2'] = $arr2;
return json_encode($data);
?>
答案 1 :(得分:0)
如何这样思考:
function getSnDataJSON($table_name){
$arr = array();
$rs = mysql_query("SELECT id, name FROM sn_" . $table_name);
while($obj = mysql_fetch_object($rs)) {
$arr[] = $obj;
}
$response = '{"'.$table_name.'":'.json_encode($arr).'}';
return $response;
}
echo getSnDataJSON('roles');
在函数中封装从db获取内容的东西,为了使其按原样工作,您需要准备好表名和表单元素名称:
即数据库中的sn_roles成为表单中的角色 要么 数据库中的角色在表单中保留为角色
这是一种思考方式,我唯一不确定的是引用初始的json回归。
enter code here
$ response ='{“'。$ table_name。'”:'。json_encode($ arr)。'}';