2014-10-04 101 views
0

我一直在嘗試使整個一天的自動完成腳本,但我似乎無法弄清楚。在PHP/Javascript中自動完成表單

​​

這是我的html。 什麼,我試圖做的是使用AJAX來自動完成第一場 這樣的:preview

當有第一輸入9號它填補了其他輸入以及使用正確的鏈接數據

在ajax.php腳本發送mysqli_query到服務器,並詢問所有 數據(表:字段||行:序號,第一,仲丁基,第三)

+0

https://twitter.github.io/typeahead.js/ – Rob 2014-10-04 19:07:53

+0

這不是我的意思,你給我的例子有一個列表,它不會像圖像中那樣完成輸入 – Kygran 2014-10-04 19:12:17

+0

它的確如此。 – Rob 2014-10-04 19:14:15

回答

0

https://github.com/ivaynberg/select2

PHP集成實施例:

<?php 
/* add your db connector in bootstrap.php */ 
require 'bootstrap.php'; 

/* 
$('#categories').select2({ 
    placeholder: 'Search for a category', 
    ajax: { 
     url: "/ajax/select2_sample.php", 
     dataType: 'json', 
     quietMillis: 100, 
     data: function (term, page) { 
      return { 
       term: term, //search term 
       page_limit: 10 // page size 
      }; 
     }, 
     results: function (data, page) { 
      return { results: data.results }; 
     } 

    }, 
    initSelection: function(element, callback) { 
     return $.getJSON("/ajax/select2_sample.php?id=" + (element.val()), null, function(data) { 

       return callback(data); 

     }); 
    } 

}); 
*/ 

$row = array(); 
$return_arr = array(); 
$row_array = array(); 

if((isset($_GET['term']) && strlen($_GET['term']) > 0) || (isset($_GET['id']) &&  is_numeric($_GET['id']))) 
{ 

if(isset($_GET['term'])) 
{ 
    $getVar = $db->real_escape_string($_GET['term']); 
    $whereClause = " label LIKE '%" . $getVar ."%' "; 
} 
elseif(isset($_GET['id'])) 
{ 
    $whereClause = " categoryId = $getVar "; 
} 
/* limit with page_limit get */ 

$limit = intval($_GET['page_limit']); 

$sql = "SELECT id, text FROM mytable WHERE $whereClause ORDER BY text LIMIT $limit"; 

/** @var $result MySQLi_result */ 
$result = $db->query($sql); 

    if($result->num_rows > 0) 
    { 

     while($row = $result->fetch_array()) 
     { 
      $row_array['id'] = $row['id']; 
      $row_array['text'] = utf8_encode($row['text']); 
      array_push($return_arr,$row_array); 
     } 

    } 
} 
else 
{ 
    $row_array['id'] = 0; 
    $row_array['text'] = utf8_encode('Start Typing....'); 
    array_push($return_arr,$row_array); 
} 

$ret = array(); 
/* this is the return for a single result needed by select2 for initSelection */ 
if(isset($_GET['id'])) 
{ 
    $ret = $row_array; 
} 
/* this is the return for a multiple results needed by select2 
* Your results in select2 options needs to be data.result 
*/ 
else 
{ 
    $ret['results'] = $return_arr; 
} 
echo json_encode($ret); 

$db->close(); 

舊版本: 在我的例子我使用的是舊Yii的項目,但你可以輕鬆地編輯您的要求。

請求以JSON編碼。 (你並不需要爲這個壽警予)

public function actionSearchUser($query) { 
    $this->check(); 
    if ($query === '' || strlen($query) < 3) { 
     echo CJSON::encode(array('id' => -1)); 
    } else { 
     $users = User::model()->findAll(array('order' => 'userID', 
      'condition' => 'username LIKE :username', 
      'limit' => '5', 
      'params' => array(':username' => $query . '%') 
     )); 
     $data = array(); 
     foreach ($users as $user) { 
      $data[] = array(
       'id' => $user->userID, 
       'text' => $user->username, 
      ); 
     } 
     echo CJSON::encode($data); 
    } 

    Yii::app()->end(); 
} 

在視圖使用本:

$this->widget('ext.ESelect2.ESelect2', array(
'name' => 'userID', 
'options' => array(
    'minimumInputLength' => '3', 
    'width' => '348px', 
    'placeholder' => 'Select Person', 
    'ajax' => array(
     'url' => Yii::app()->controller->createUrl('API/searchUser'), 
     'dataType' => 'json', 
     'data' => 'js:function(term, page) { return {q: term }; }', 
     'results' => 'js:function(data) { return {results: data}; }', 
    ), 
), 

));

下面的腳本是從官方資料爲準,可能更容易採取到:

$("#e6").select2({ 
     placeholder: {title: "Search for a movie", id: ""}, 
     minimumInputLength: 1, 
     ajax: { // instead of writing the function to execute the request we use Select2's convenient helper 
      url: "http://api.rottentomatoes.com/api/public/v1.0/movies.json", 
      dataType: 'jsonp', 
      data: function (term, page) { 
       return { 
        q: term, // search term 
        page_limit: 10, 
        apikey: "ju6z9mjyajq2djue3gbvv26t" // please do not use so this example keeps working 
       }; 
      }, 
      results: function (data, page) { // parse the results into the format expected by Select2. 
       // since we are using custom formatting functions we do not need to alter remote JSON data 
       return {results: data.movies}; 
      } 
     }, 
     formatResult: movieFormatResult, // omitted for brevity, see the source of this page 
     formatSelection: movieFormatSelection // omitted for brevity, see the source of this page 
    }); 

這可以在這裏找到:http://ivaynberg.github.io/select2/select-2.1.html

您可以在GitHub的倉庫optain的選擇2副本以上。