2013-04-04 23 views
2

我有状态字段作为下拉列表。在改变州时,应在复选框中查看城市。下面是我的代码Drupal 7复选框数组替换ajax回调

$form['rate_the_service']['state'] = array(
    '#type' => 'select', 
    '#prefix'=>'<div id="dropdown-third-replace">', 
    '#suffix'=>'</div>', 
    '#options'=>array(
    '0' => t('state1'), 
    '1' => t('state2'), 
    '2' => t('state3') 
), 
    '#attributes' => array(
    'selected' => array('selected') 
), 
    '#validated' => TRUE, 
    '#ajax' => array(
    'callback' => 'ajax_example_dependent_dcheck_state_callback', 
    'wrapper' => 'checkboxes-four-replace', 
), 
    '#suffix'=>'</div>', 
); 

所以,当上改变国家的城市将要使用的回调函数“ajax_example_dependent_dcheck_state_callback”

下面是默认的城市代码显示在复选框:

$cityarray = array(
    '1' => 'chk1' 
); 

$form['rate_the_service']['city'] = array(
    '#prefix'=>'<div id="checkboxes-four-replace">', 
    '#type' => 'checkboxes', 
    '#options' => $cityarray, 
    '#default_value' => isset($values['city']) ? $values['city'] : NULL, 
    '#suffix'=>'</div></div>', 
); 

///////////转换ajax_example_dependent_dcheck_state_callback函数调用

function ajax_example_dependent_dcheck_state_callback($form, $form_state) { 
    $state = $form_state['values']['state']; 
    $city_array = array(
    '0' => 'city1', 
    '2' => 'city2', 
    '3' => 'city3' 
); 
    $options[$state] = $city_array; 
    $form['rate_the_service']['city']['#options'] = $city_array; 
    return $form['rate_the_service']['city']; 
} 

在onchange状态时,'checkboxes-four-replace'将被替换为city1,2,3复选框

onchange功能不起作用。如果我改变类型为''#type'=>'选择''而不是''#type'=>'复选框'“,它的工作正常。但我需要这个复选框。我在这里错了什么。请帮帮我。

+0

+ 1有同样的问题。 replace()函数似乎不被支持。 – Atomox 2013-05-29 17:43:58

+0

我有一个工作解决方案,我嘲笑起来 - 但我不想分享,直到你澄清这句话:你的帖子的开始是令人困惑的:你的句子陈述“虽然onchange州的城市应该在复选框中查看。下面是我的代码“〜国家应该是复选框还是选择? – inertialmedia 2013-05-31 13:56:28

回答

0

你的帖子的开头令人困惑:你的句子陈述“在更改状态时城市应该在复选框中查看,下面是我的代码”〜州应该是复选框或选择?

无论哪种方式,我有这样的使用状态的代码为“选择”和城市为“复选框”:

function state_form($form, &$form_state) { 
    $form = array(); 

    $form['rate_the_service']['state'] = array(
    '#type' => 'select', 
    '#prefix'=>'<div id="dropdown-third-replace">', 
    '#suffix'=>'</div>', 
    '#options'=>array(
     '0' => t('Ohio'), 
     '1' => t('New York'), 
    ), 
    '#validated' => TRUE, 
    '#ajax' => array(
     'event' => 'change', 
     'callback' => 'ajax_example_dependent_dcheck_state_callback', 
     'wrapper' => 'checkboxes-four-replace', 
    ), 
); 

    $city_array = array(
    '1' => array(
     '1' => 'Cincinnati', 
     '2' => 'Cleveland', 
     '3' => 'Toledo' 
    ), 
    '2' => array(
     '4' => 'New York City', 
     '5' => 'Buffalo', 
     '6' => 'Syracuse' 
    ), 
); 

    if (isset($form_state['values']['state']) && $form_state['values']['state'] == 1) { 
    $form['rate_the_service']['city'] = array(
     '#prefix'=>'<div id="checkboxes-four-replace">', 
     '#type' => 'checkboxes', 
     '#options' => $city_array[2], 
     '#default_value' => isset($values['city']) ? $values['city'] : array('1'), 
     '#suffix'=>'</div></div>', 
    ); 
    } else { 
    $form['rate_the_service']['city'] = array(
     '#prefix'=>'<div id="checkboxes-four-replace">', 
     '#type' => 'checkboxes', 
     '#options' => $city_array[1], 
     '#default_value' => isset($values['city']) ? $values['city'] : array('2'), 
     '#suffix'=>'</div></div>', 
    ); 
    } 
    return $form; 
} 

/** 
* Ajax Callback for development_form 
*/ 
function ajax_example_dependent_dcheck_state_callback($form, $form_state) { 
    return $form['rate_the_service']['city']; 
} 

可选,如果你想要的状态是“复选框”,以及城市,你可以这样做:

function state_form($form, &$form_state) { 
    $form = array(); 

    $form['rate_the_service']['state'] = array(
    '#type' => 'checkboxes', 
    '#prefix'=>'<div id="dropdown-third-replace">', 
    '#suffix'=>'</div>', 
    '#options'=>array(
     'ohio' => t('Ohio'), 
     'new_york' => t('New York'), 
    ), 
    '#validated' => TRUE, 
    '#ajax' => array(
     'event' => 'change', 
     'callback' => 'ajax_example_dependent_dcheck_state_callback', 
     'wrapper' => 'checkboxes-four-replace', 
    ), 
); 

    $city_array = array(
    '1' => array(
     '1' => 'Cincinnati', 
     '2' => 'Cleveland', 
     '3' => 'Toledo' 
    ), 
    '2' => array(
     '4' => 'New York City', 
     '5' => 'Buffalo', 
     '6' => 'Syracuse' 
    ), 
); 

    // refine as needed to fit your validation, if this is your use case 
    if (isset($form_state['values']['state']['ohio']) && $form_state['values']['state']['ohio'] == 'ohio') { 
    $form['rate_the_service']['city'] = array(
     '#prefix'=>'<div id="checkboxes-four-replace">', 
     '#type' => 'checkboxes', 
     '#options' => $city_array[1], 
     '#default_value' => isset($values['city']) ? $values['city'] : array('1'), 
     '#suffix'=>'</div></div>', 
    ); 
    } else if (isset($form_state['values']['state']['new_york']) && $form_state['values']['state']['new_york'] == 'new_york') { 
    $form['rate_the_service']['city'] = array(
     '#prefix'=>'<div id="checkboxes-four-replace">', 
     '#type' => 'checkboxes', 
     '#options' => $city_array[2], 
     '#default_value' => isset($values['city']) ? $values['city'] : array('2'), 
     '#suffix'=>'</div></div>', 
    ); 
    } else { 
    $form['rate_the_service']['city'] = array(
     '#prefix'=>'<div id="checkboxes-four-replace">', 
     '#type' => 'checkboxes', 
     '#options' => array(), 
     '#default_value' => isset($values['city']) ? $values['city'] : array('2'), 
     '#suffix'=>'</div></div>', 
    ); 
    } 
    return $form; 
} 

/** 
* Ajax Callback for development_form 
*/ 
function ajax_example_dependent_dcheck_state_callback($form, $form_state) { 
    return $form['rate_the_service']['city']; 
} 

,这里是与各国的“选择”框和城市作为一个“选择”框的情况下

function state_form($form, &$form_state) { 
    $form = array(); 

    $form['rate_the_service']['state'] = array(
    '#type' => 'select', 
    '#prefix'=>'<div id="dropdown-third-replace">', 
    '#suffix'=>'</div>', 
    '#options'=>array(
     'ohio' => t('Ohio'), 
     'new_york' => t('New York'), 
    ), 
    '#validated' => TRUE, 
    '#ajax' => array(
     'event' => 'change', 
     'callback' => 'ajax_example_dependent_dcheck_state_callback', 
     'wrapper' => 'checkboxes-four-replace', 
    ), 
); 

    $city_array = array(
    '1' => array(
     '1' => 'Cincinnati', 
     '2' => 'Cleveland', 
     '3' => 'Toledo' 
    ), 
    '2' => array(
     '4' => 'New York City', 
     '5' => 'Buffalo', 
     '6' => 'Syracuse' 
    ), 
); 

    if (isset($form_state['values']['state']) && $form_state['values']['state'] == 'new_york') { 
    $form['rate_the_service']['city'] = array(
     '#prefix'=>'<div id="checkboxes-four-replace">', 
     '#type' => 'select', 
     '#options' => $city_array[2], 
     '#default_value' => isset($values['city']) ? $values['city'] : array('1'), 
     '#suffix'=>'</div></div>', 
    ); 
    } else { 
    $form['rate_the_service']['city'] = array(
     '#prefix'=>'<div id="checkboxes-four-replace">', 
     '#type' => 'select', 
     '#options' => $city_array[1], 
     '#default_value' => isset($values['city']) ? $values['city'] : array('2'), 
     '#suffix'=>'</div></div>', 
    ); 
    } 
    return $form; 
} 

/** 
* Ajax Callback for development_form 
*/ 
function ajax_example_dependent_dcheck_state_callback($form, $form_state) { 
    return $form['rate_the_service']['city']; 
}