0

ここに画像の説明を入力 私がやろうとしているのは、ajax でボタンを押すと、チェックボックス付きのテーブルを表示することです。テーブルは最初は非表示にして、関数呼び出しによってその場で入力する必要があります。最初に $options1 をいくつかのダミー値でロードすると、ajax 呼び出しの後に次のエラーがスローされます。

Notice: 未定義のインデックス: theme_tableselect() の red (D:\wamp\www\drupal7\includes\form.inc の 3285 行目)。

ここで、'red' はダミー行の値のインデックスであり、#options には新しい値が取り込まれません。これを機能させる方法は何ですか?

フォームのコードは次のとおりです-

$form['mltag_new']['tag'] = array(
        '#type' => 'button',
        '#value' => t("Suggest Tags"),
        '#ajax' => array(
            'callback' => 'mltag_suggest_tags_ajax',
            'wrapper' => 'mltag_suggest_tags_table_div',
            'effect' => 'slide',
            ),
    );




 $options1 = array();                      //initial dummy values
    $options1['red']['tag'] = "A red row";
    $options1['red']['chi'] = "A red row";


 $form['mltag_new']['myselector'] = array (
        '#type' => 'tableselect',
        '#title' => 'My Selector',
        '#header' => $header,
        '#options' => $options1,
        '#prefix' => '<div id="mltag_suggest_tags_table_div">',
        '#suffix' => '</div>',        
    );

    return $form;

Ajax コールバックは次のようになります。

function mltag_suggest_tags_ajax($form, $form_state) {
          //$content has some content
          //pass the content to a function 
          include_once 'includes/content_tag.inc';
          $tags = mltag_content_tag($content, variable_get('algo_type'), 20);

          if (empty($tags)) {
            $output .= t('Content is insufficient to generate Tags using this algorithm. <br>Please choose other algorithm from Settings Page.');
            $form['mltag_new']['sample_text']['#markup'] = $output;
            return $form['mltag_new']['sample_text'];
          }
          else {
            $algo = variable_get('algo_type');
            if ($algo == 1) {
              $header = array(
                  'tag' => t('Tag'),
                  'frequency' => t('Frequency'), 
                  );

              $options = array();      
              foreach ($tags as $key => $value) {
                $options[$key] = array(
                    'tag' => $key,
                    'frequency' => $value,
                    );
              }    
            }

            elseif ($algo == 2) {
              $header = array(
                  'tag' => t('Tag'),
                  'chi' => t('Chi Square Value'), 
                  );

              $options = array();

              foreach ($tags as $key => $value) {
                $options[$key] = array(
                    'tag' => $key,
                    'chi' => $value,
                ); 
              } 

            }

          $form['mltag_new']['myselector']['#header'] = $header; 
          $form['mltag_new']['myselector']['#options'] = $options;
          return $form['mltag_new']['myselector'];
          }
}
4

2 に答える 2

2

Drupal.org でのあなたの投稿に、似たような問題にどのように取り組んでいるかについて返信しました。追加してみる

$form['mltag_new']['myselector'] =
    form_process_tableselect($form['mltag_new']['myselector']);

お帰りの直前。うまくいけば、それは私よりもあなたを助けます。#options は、ブロックが ajax からリロードされるときにレンダリングされるだけですが、元の $form オブジェクトは認識していないように見えることに注意してください。

于 2012-08-10T20:20:41.853 に答える