Php 从Ajax发送到codeigniter控制器的数据

Php 从Ajax发送到codeigniter控制器的数据,php,ajax,codeigniter,Php,Ajax,Codeigniter,我试图通过Ajax将用户名从视图发送到控制器,如下所示: $('#exampleFormControlSelect1').change(function(){ var username =$('#exampleFormControlSelect1').val(); $.ajax({ type: 'POST', dataType: "json", url: "Panier/loadPanier"

我试图通过Ajax将用户名从视图发送到控制器,如下所示:

 $('#exampleFormControlSelect1').change(function(){
     var  username =$('#exampleFormControlSelect1').val();

        $.ajax({
            type: 'POST',
            dataType: "json",
            url: "Panier/loadPanier",
            data: {username: username},
            success: function(result){
                $("#tbodyid").empty();
                var data1 = JSON.parse(result);
                console.log(data1) ;
            },

        });

    });
我尝试使用发送的值来做一些工作:

    public function loadPanier()
{

    $res = [];
    $username = $this->input->post('username');

    $panier_data = $this->model_panier->getPanierData($username);

    foreach ($panier_data as $k => $v) {
        $idPiece = $v['idPiece'];
        $qte = $v['quantity'];
        $piece_data = (array)$this->model_catalogue->getDetail($idPiece);

        $price = (int)$piece_data['Unit Price'];
        $montant = $qte * $price;

        array_push($res, array(
            'idPiece' => $idPiece,
            'Description' => $piece_data['Description'],
            'qte' => $qte,
            'prix HT' => round($piece_data['Unit Price'], 3),
            'montant' => $montant
        ));
    }

    return $res;
}
在我的URL中,我遇到以下错误:

为foreach提供的参数无效

但通过使用var_dump$username,我注意到了以下几点:

C:\wamp64\www\portaldaler\application\controllers\Panier.php:66:null

所以我的数据没有通过

你能帮我吗

编辑

展示这部分代码的结果:

    var_dump($_REQUEST);
    $res = [];
    $username = $this->input->post('username');
        var_dump($username);
    $panier_data = $this->model_panier->getPanierData($username);
    var_dump($panier_data);

下面的代码应将您的数据发送到Panier/loadPanier/

每次执行var_转储时都会看到null,因为您试图独立加载页面。只有通过表单进入页面时,页面才会提供POST值,在本例中,表单是javascript。在javascript中使用POST方法加载页面时,响应将通过ajax发送到同一页面,这样您就可以在不刷新页面的情况下使用代码

另外:不能将数据返回到javascript。您必须将其打印到客户端,以便javascript的JSON解析器能够读取它。因此,不是返回$res;:


您确定:var username=$'exampleFormControlSelect1.val.行中没有缺少结束分号吗?否,我已修复了该问题,但在执行var_dump时仍然得到空值。在devtool的“网络”选项卡中,当您发送请求时,请求是否发送了正确的post参数?是的,它发送了正确的参数,因此它发送了用户名post数据及其值?您能在控制器上尝试var_dump$请求并查看结果吗?仍然给出相同的结果。你可以看到编辑后的帖子
$('#exampleFormControlSelect1').change(function(){
    var  val1 =$('#exampleFormControlSelect1').val();
    $.ajax({
        method: "POST",
        url: "Panier/loadPanier/",
        data: { username: val1}
    }).done(function( result ) {
        $("#tbodyid").empty();
        var data1 = JSON.parse(result);
        console.log(data1) ;
    });
});
echo json_encode($res);