我不知道如何在hook_form_alter()中实现AJAX。
字段默认为纯文本,并由客户公司的NID(数字)填充。模块名称为“ my_car”。我没有在此字段上使用节点引用。
代码如下:
function my_car_form_alter(&$form, &$form_state, $form_id) {
if ($form_id == 'car_node_form') {
$clientCompanies = companyTitle(12); // TID 12
// Replace Client company NID with title
$form['field_car_company']['und'][0]['value'] = array(
'#title' => 'Client company',
'#type' => 'select',
'#default_value' => $form_state['node']->field_car_company['und'][0]['value'],
'#options' => $clientCompanies,
'#required' => TRUE,
'#empty_option' => t('- Select -')
);
}
}
在这里,我使用companyTitle()函数返回所有具有TID 12的公司(节点),并将字段类型(“ textfield”替换为“ select”)及其内容-用文本编号(带有标题的NID)。
function companyTitle($tid) {
$results = db_query("
SELECT n.nid, n.title
FROM {node} AS n
LEFT JOIN {field_data_field_company_type} AS ct ON ct.entity_id = n.nid
WHERE n.type = 'company' AND ct.field_company_type_tid = :tid
ORDER BY n.title ASC",
array(':tid' => $tid))->fetchAllKeyed();
return $results;
}
我编写了基于TID和标题返回客户公司的NID和标题的函数:
function ajaxCompanyTitle($tid, $companyName) {
$query = db_select('node', 'company')
->fields('company', array('nid', 'title'))
->condition('company.type', 'company', '=')
->condition('type.field_company_type_tid', $tid, '=')
->condition('company.title', '%'.db_like($companyName).'%', 'LIKE')
->orderBy('company.title', 'ASC')
->range(0, 10);
$query->leftJoin('field_data_field_company_type', 'type', 'type.entity_id = company.nid');
$results = $query->execute()->fetchAll();
return $results;
}
现在是一个问题,如何使用最后一个功能实现AJAX。我需要AJAX搜索的文本字段(不是选择列表),其中NID将呈现为标题(NID仅保留在field_car_company_value列中的数据库中)。
显然我不知道如何实现回调函数。
function my_car_form_alter(&$form, &$form_state, $form_id) {
if ($form_id == 'car_node_form') {
// Replace Client company NID with title
$form['field_car_company']['und'][0]['value'] = array(
'#title' => 'Client company',
'#type' => 'textfield',
'#required' => TRUE,
'#ajax' => array(
'callback' => 'ajax_callback',
'wrapper' => 'edit-field-car-company-und-0-value',
)
);
}
}
function ajax_callback($string = '') {
$matches = array();
if ($string) {
$clientCompanies = ajaxCompanyTitle(12, $string);
foreach ($clientCompanies as $clientCompany) {
$matches[$clientCompany->title] = $clientCompany->title;
}
}
drupal_json_output($matches);
}