尝试在symfony1.4表单模板中使用jquery ajax编写动态依赖选择的代码。 我编写了代码,我可以从下拉列表中获取用户选择的第一个字段值,并将其传递给我的php函数以获取用于选择第二个下拉列表值的数据。我可以从php函数将返回值传递给ajax函数但我无法使用此值选择我的下拉列表值
这里我给了我的代码。请给出建议。
代码:
_form.php这个
<script type="text/javascript">
jQuery(document).ready(function() {
$("#application_program_institution_program_id").change(function(){
var id=$(this).val();
if(id != '') {
$.ajax({
type: "POST",
url: '<?php echo url_for('Application/Program'); ?>'+ '?id=' + id,
cache: false,
success: function(data)
{
alert(data);// its show my returned value
$("#application_campus_campus_id").val(data);// but it does not select the value of dropdown list.
}
});
}
});
});
</script>
Applicationaction类
public function executeProgram(sfWebRequest $request) {
$id = intval($request->getParameter('id'));
$campusList = InstitutionCampus::getCampus($id);
return $this->renderPartial('result', array('campusList' => $campusList));
}
getCampus代码:
public static function getCampus($id) {
$resultset = Doctrine_Query::create()
->select('ip.id as id, ip.program_code as title, ic.id as ip, ic.campus_name as campusname, icp.institution_campus_id')
->from('InstitutionCampusProgram icp')
->innerJoin('icp.InstitutionProgram ip')
->innerJoin('ip.Institution i')
->innerJoin('icp.InstitutionCampus ic')
->where('ip.all_campus = ?', '0')
->andWhere('i.institution_code = ?', CodeUtil::UttaraUniversity)
->andWhere('icp.institution_program_id =?', $id)
->execute();
foreach ($resultset as $prog){
$result = $prog->ip;
}
return $result;
}
}
_result.php代码:
<?php echo $campusList; ?>
答案 0 :(得分:2)
好吧,上面应该可行,但也可以试试这个:
<script type="text/javascript">
jQuery(document).ready(function() {
$("#application_program_institution_program_id").change(function(){
var id=$(this).val();
if(id != '') {
var r = $.ajax({
type: "POST",
url: '<?php echo url_for('Application/Program'); ?>'+ '?id=' + id,
});
$("#application_campus_campus_id").val(r);
}
});
});
还要将getCampus.php代码的最后一行从return $ result更改为返回$ result [0],如果返回单个值,请记住你要返回一个数组,你应该将php数组更改为javascript你可以用json_encode做的数组。