CI中的Ajax问题。获取数据但JQuery显示错误

时间:2018-05-24 16:58:37

标签: javascript php jquery json codeigniter

我有以下代码

<?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数据?

如果欢迎参加考试  和开始考试正在创建问题,然后如何解决?

1 个答案:

答案 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>