我有以下代码
<?php
$arr=array();
$arr=$this->session->ques;
if(isset($this->session->username))
{
echo '<div id="instruction">
Welcome to Exam
</div>';
echo '<div id="questdiv">
Start Now
</div>';
}
?>
$(document).ready(function(){
$("#questdiv").click(function()
{
$("#instruction").hide();
$.ajax({
type:"post",
url:"<?php echo base_url();?>"+"candidate/nextques",
dataType:"json",
data:{val: <?php echo json_encode($arr);?>},
success:function(res){
if(res)
{
$("#questdiv").append('<span>'+res[0]['question']);
$("#questdiv").append('<span>'+res[0]['option1']);
$("#questdiv").append('<span>'+res[0]['column2']);
$("#questdiv").append('<span>'+res[0]['column3']);
$("#questdiv").append('<span>'+res[0]['column4']);
}
},
error: function(res,status,error) {
var err = res.responseText;
alert(res.Message);
alert(status);
alert(error);
}
});
});
});
</script>
在这段代码中,我有两个div。我希望在单击div questdiv 时,AJAX应该触发,从控制器模型中获取值并在div中附加一些子项。
虽然数据是从数据库中提取的(如网络调试所示),但是预览还显示了上面两个div,因为我得到了JSON解析错误。
[{"sno":"1","examcode":"PHP-101","question":"What is PHP?","image":"1-1.jpg","option1":"scripting language","image1":"1-2.jpg","option2":"programming language","image2":"1-3.jpg","option3":"both","image3":"1-4.jpg","option4":"none","image4":"1-5.jpg","correctans":"d58abf157fec3d16bf921e97966c9e57"}]
Welcome to Exam
Start Now
我无法弄清楚为什么我从控制器获得解析错误,我只获得有效的JSON数据?
如果欢迎参加考试 和开始考试正在创建问题,然后如何解决?
答案 0 :(得分:1)
你应该有单独的控制器方法,一个用div渲染页面,另一个只返回你的json对象。你是这样做的,你不会有一个有效的json对象,因为div也在那里渲染(因为它实际上是在ajax调用上重新渲染页面)。
示例:
class Some_controller {
public function index() {
$this->load->view('someview');
}
public function json() {
$array = array('123', '456');
echo json_encode($array);
}
}
Someview:
<script>
$(document).ready(function () {
$('#doAction').on('click', function (e) {
e.preventDefault();
$.ajax({
type: "get",
url: "<?php echo base_url(); ?>some_controller/json",
dataType: "json",
success: function (res) {
console.log(res);
}
});
});
});
</script>
<div><a id="doAction" href="javascript:void()">Some div</a></div>