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

0

我用简单的 HTML 尝试了你的代码,它在请求中显示了 layout_actions[] 数组

我看到你在单引号中使用变量 $context ....

所以我认为这就是为什么它不采用 select Box 的 Multiple 属性的原因

 echo '<select id="actions_list" name="layout_actions[]" multiple style="height: 128px; width: 300px;', (isset($context['layout_error']['no_actions']) ? ' border: 1px solid red;' : ''), '">';
于 2013-09-02T11:58:16.650 回答