0

私は ajax を初めて使用し、コントローラーで変数を投稿したり、それらの変数にアクセスしたりするのに問題があります。

ここにコントローラーコードがあります

class autocomplete extends CI_Controller {
  // just returns time
  function workdammit()
  {
    $product = $this->input->post('productName');
/*      $this->load->model('product_model');
    $q = 'SELECT quantity FROM products WHERE productName = "BC20BA"';
    $data = $this->product_model->get_record_specific($q);

    echo json_encode($data[0]->quantity);
*/
    echo $product;

  }

  function index()
  {
    $this->load->view('autocomplete_view');
  } 
}

echoをこのように一重引用符で囲んだ文字列に変更すると'Hello World'Hello Worldがビューに正しく返されます。しかし、現在のように試してみると、同じことはできません。また、それを使用するecho json_encode($product);とfalseが返されます。

ここに ajax を使用したビュー コードがあります。

$( document ).ready(function () {
  // set an on click on the button
  $('#button').click(function () {
        $.ajax({
    type: "POST",
    url: "<?php echo site_url('autocomplete/workdammit'); ?>",
    dataType: "json",
    data: 'productName',
    success: function(msg){  
        alert(msg);

    }
    });
  });
});
</script>
</head>
<body>
  <h1> Get Data from Server over Ajax </h1>

 <br/>
  <button id="button">
     Get posted varialbe
 </button>
4

1 に答える 1

1
class autocomplete extends CI_Controller {
// just returns time
    function workdammit()
    {
        $product = $this->input->post('productName');
        //echo $product;
        //in ajax dataType is json -here You have to return json data
        echo json_encode($product);
    }
...
}    

//javascript file
var productName = $('#productName).val();//get value of product name from form

$('#button').click(function () {
    $.ajax({
    type: "POST",
    url: "<?php echo site_url('autocomplete/workdammit'); ?>",
    dataType: "json",
    data: {productName:productName},//You have to send some data from form
    success: function(msg){  
        alert(msg);

    }
});
于 2013-08-31T22:07:21.870 に答える