0

わかりました、次のように、JavaScriptを介して別の選択ボックスからのオプションで複数の選択ボックスを埋めています:

function addAction()
{
    var actions = document.getElementById("actions");
    var action_list = document.getElementById("actions_list");
    var opt = document.createElement("option");
    for (var i=0; i<action_list.options.length; i++)
    {
        if (action_list.options[i].text == actions.options[actions.selectedIndex].text)
            return;
    }
    action_list.options.add(opt);
    opt.text = actions.options[actions.selectedIndex].text;
    opt.value = actions.options[actions.selectedIndex].value;
}

function removeActions()
{
    var action_list = document.getElementById("actions_list");
    for(i=action_list.options.length-1;i>=0;i--)
    {
        if (action_list.options[i].selected)
            action_list.remove(i);
    }
}

$layout_actions[]上記のJSを介して1つの選択ボックスからこの1に値を追加すると、次のようにEMPTYが返されます。

echo '<select id="actions_list" name="layout_actions[]" multiple style="height: 128px; width: 300px;', (isset($context['layout_error']['no_actions']) ? ' border: 1px solid red;' : ''), '">';
                            foreach($context['current_actions'] as $cur_action)
                                echo '
                                    <option value="', $cur_action, '">', $cur_action, '</option>';  

        echo '
                                    </select>

つまり、my $_POST['layout_actions'] = ''(空の文字列)。ここで何が起こっているのですか?これは機能するはずですよね?

私を助けてください... argg。[追加] ボタンをクリックすると、1 つの選択ボックスから複数の選択ボックスに移動することがわかるので、要素が追加されていることはわかっていますが、フォームを投稿すると、layout_actions は空を返します。

4

1 に答える 1