Cakephp3 jQuery自动完成

时间:2016-07-05 13:34:07

标签: jquery ajax autocomplete cakephp-3.0

我是CakePHP3的新手(+ stackoverflow)并尝试实现自动完成功能。我想将自动完成功能附加到index.ctp中的searchinput。

  1. 请求返回所有car-objects(忽略get.term)
  2. 响应未附加到searchinput
  3. 可以得到一些帮助 - 谢谢!

    index.ctp

    <?php
    echo $this->Form->create('Cars');
        echo $this->Form->input('name', [
                'label' => 'Search',
                'id' => 'autocomplete',
                'class' => 'ui-autocomplete'
        ]);
    echo $this->Form->button('Search', ['type' => 'submit']);
    echo $this->Form->end();
    ?>
    <script>
    $("#autocomplete").autocomplete(
        {
            search: function () {},
            source: function (request, response)
            {
                $.ajax(
                {
                    source: "/cars/autocomplete",
                    dataType: "json",
                    data:
                    {
                        term: request.term,
                    },
                    success: function (data)
                    {
                        response(data);
                        console.log(data);
                    }
                });
            },
            minLength: 2
        });
    </script>
    

    CarsController.php

    function autocomplete() {
        if ($this->request->is('ajax','get')) {
            $term = $this->request->data["term"];
            $terms = $cars->find('all', [
                'conditions' => ['Cars.name >' => $term],
                'limit' => 10
            ]);
    
        $data = array();
            foreach($terms as $term) {
                $row = $term->name;
                array_push($data, $row);
            }
    
            // $this->layout = 'ajax';
            $this->set('terms', $terms);
            echo json_encode($data);
        // return json_encode($data);
        }
        else {
            echo json_encode('Nothings found');
        }
    }
    

1 个答案:

答案 0 :(得分:0)

好的,我刚刚找到了解决方案(可能不是完美的?!)。这是我的代码

<强> index.ctp

<script>
$( function() {
$( "#autocomplete" ).autocomplete({
    minLength: 1,
    source: function( request, response ) {
        $.ajax({
            url: "<?php echo Router::url(['controller' => 'Cars', 'action' => 'autocomplete']);?>" + '?term=' +
                request.term,
                dataType: "json",
                success: function (data)
                {
                    response(data);
                    console.log(data);
                }
          });
      }
  });
});
</script>

CarsController.php操作自动填充

public function autocomplete() {
    $this->autoRender = false;
    $terms = $this->Cars->find('list', array(
            'conditions' => array(
                    'Cars.name LIKE' => trim($this->request->query['term']) . '%'
            )
    ));
    echo json_encode($terms);   
}