1

我是如何设法让它工作的。但是结果仍然没有与自动完成一起出现。

现在发布我的最新代码,

文本字段代码

$form['town'] = array(
'#type' => 'textfield',
'#required' => TRUE,
'#autocomplete_path' => 'hfind/town/autocomplete',
);

菜单功能码

function hfind_menu() {
  $items = array();
  $items['hfind/town/autocomplete'] = array (
    'title' => 'Autocomplete for cities',
    'page callback' => 'hfind_town_autocomplete',
    'access arguments' => array('use autocomplete'),
    'type' => MENU_CALLBACK
   );
return $items;
}

回调函数代码

function hfind_town_autocomplete($string){
  $matches = array();
  $result = db_select('towns', 't')
    ->fields('t', array('town_name'))
    ->condition('town_name', '%' . db_like($string) . '%', 'LIKE')
    ->execute();
  foreach ($result as $row) {
    $matches[$row->city] = check_plain($row->city);
  }
  drupal_json_output($matches);
}

我希望这可能是最后的编辑。

目前的情况是,自动完成功能正在运行

网址是 hfind/town/autocomplete/mtw

但它无法从数据库中找到任何数据。我找到了原因并且无法修复它。这是因为在我在上面添加的最后一个函数中,$string 需要是“搜索查询”,但它始终将数据库查询为“自动完成”。我的意思是 $string 变量始终具有值“自动完成”而不是用户键入的值。

另一个问题是,即使在向所有类型的用户提供访问表单上的搜索自动完成的权限之后,访客用户也无法使用该功能。

请有人帮助我..

4

1 回答 1

0
`drupal_json_output()` instead of `drupal_to_js` and remove `print` .
<code>
hook_menu() {
$items['cnetusers/autocomplete'] = array(
    'title' => 'Auto complete path',
    'page callback' => 'cnetusers_employees_autocomplete',
    'page arguments' => array(2, 3, 4, 5),
    'access arguments' => array('access user profiles'),
    'type' => MENU_CALLBACK,
  );
return $item;
}
// my autocomplete function is like this
function cnetusers_employees_autocomplete() {
  // write your sql query
    $matches["$record->ename $record->elname [id: $record->uid]"] = $value;
  }
  if (empty($matches)) {
    $matches[''] = t('No matching records found.');
  }
  drupal_json_output($matches);
}

$form['disc_info']['approval'] = array(
      '#type' => 'textfield',
      '#title' => t('Approval By'),
      '#autocomplete_path' => 'cnetusers/autocomplete',
    );
</code>
于 2013-08-23T10:34:23.097 回答