CodeIgniter - 如何从控制器返回Json响应

时间:2013-09-16 06:18:35

标签: javascript php codeigniter

如何将控制器的响应返回给Jquery Javascript?

的Javascript

$('.signinform').submit(function() { 
   $(this).ajaxSubmit({ 
       type : "POST",
       url: 'index.php/user/signin', // target element(s) to be updated with server response 
       cache : false,
       success : onSuccessRegistered,
       error: onFailRegistered
   });        
   return false; 
}); 

数据返回null(空白)!

function onSuccessRegistered(data){
    alert(data);
};

控制器 -

public function signin() {
    $arr = array('a' => 1, 'b' => 2, 'c' => 3, 'd' => 4, 'e' => 5);    
    echo json_encode( $arr );
}

5 个答案:

答案 0 :(得分:68)

return $this->output
            ->set_content_type('application/json')
            ->set_status_header(500)
            ->set_output(json_encode(array(
                    'text' => 'Error 500',
                    'type' => 'danger'
            )));

答案 1 :(得分:38)

//do the edit in your javascript

$('.signinform').submit(function() { 
   $(this).ajaxSubmit({ 
       type : "POST",
       //set the data type
       dataType:'json',
       url: 'index.php/user/signin', // target element(s) to be updated with server response 
       cache : false,
       //check this in Firefox browser
       success : function(response){ console.log(response); alert(response)},
       error: onFailRegistered
   });        
   return false; 
}); 


//controller function

public function signin() {
    $arr = array('a' => 1, 'b' => 2, 'c' => 3, 'd' => 4, 'e' => 5);    

   //add the header here
    header('Content-Type: application/json');
    echo json_encode( $arr );
}

答案 2 :(得分:1)

对于CodeIgniter 4,您可以使用内置的API Response Trait

以下示例代码可供参考:

<?php namespace App\Controllers;

use CodeIgniter\API\ResponseTrait;

class Home extends BaseController
{
    use ResponseTrait;

    public function index()
    {
        $data = [
            'data' => 'value1',
            'data2' => 'value2',
        ];

        return $this->respond($data);
    }
}

答案 3 :(得分:0)

这不是您的答案,这是处理表单提交的另一种方法

$('.signinform').click(function(e) { 
      e.preventDefault();
      $.ajax({
      type: "POST",
      url: 'index.php/user/signin', // target element(s) to be updated with server response 
      dataType:'json',
      success : function(response){ console.log(response); alert(response)}
     });
}); 

答案 4 :(得分:0)

就我而言,我使用的是 ci4 ,我像这样向 clinet 发送响应: 例如在 App\Controllers\Category:setOrder 我的类别控制器扩展了 BaseController

  return $this->response->setJson(['msg'=>'update-success']);