我有一个应用程序,它在一个选择表单中获取模型。根据模型的选择加载imei范围。
首次选择id:model第二次选择id:imeirange
Jquery/ajax代码如下
<script type="text/javascript">
$(document).ready(function() {
$('#model').change(function() {
$.ajax({
type: "POST",
url: "development/getimei",
data: "model="+$('#model').val(),
dataType: 'json',
success: function(imeivalues){
$("p").append(imeivalues+"<br/>");
alert("sucessful handshake");
$('#imeirange').empty();
$.each(imeivalues,function(id,imeivalue)
{
var opt = $('<option/>'); // here we're creating a new select option for each group
opt.val(id);
opt.text(imeivalue);
$('#imeirange').append(opt);
});
},
error: function(xhr, status, error) {
var msg=xhr.responseText;
//document.getElementById("notice").innerHTML = xhr.responseText;
var status=xhr.status;
var error="ReadyState: "+xhr.readyState+"nstatus: "+xhr.status+"nresponseText: "+xhr.responseText.Error;
alert(error);
},
});
});
});
</script>'
型号代码如下
function getimeibymodel($model){
if($model){
$this->db->select('id,imeifrom,imeito');
$this->db->where('mname',$model);
$query=$this->db->get('models');
$imeirange=Array();
if ($query->num_rows() > 0)
{
foreach ($query->result() as $imei) {
$from=$imei->imeifrom;
$to=$imei->imeito;
$imeivalue = $from.'-'.$to;
$imeivalues[$imei->id] = $imeivalue;
//var_dump($imeirange);
}
return $imeivalues;
//return $query->result();
}else{
return 'Database Error';
}
} else return 'No Model Found';
}
控制器的最后一个代码调用
public function getimei(){
$this->load->model('dev');
$model = $this->input->post('model');
header('Content-Type: application/x-json; charset=utf-8');
echo json_encode($this->dev->getimeibymodel($model), JSON_FORCE_OBJECT);
//$imeirange = $this->dev->getimeibymodel($model);
//var_dump($imeirange);
//echo json_encode($imeirange);
}
Issue无法加载具有imei范围的第二个选择框。
请帮我一下。
确保你发布的链接是正确的,在FireFox中使用类似fireBUG的东西来调试它。
你的数据格式不正确,应该是这样的:
data: { 'model': $('#model').val() },
只有一个建议,
在你的脚本末尾,我可以看到
</script>'
一个`coute->`
删除它并尝试。。。。。。。。。。。。。。。。。。。。。
</script>