强制选择列表的所有选项在单击时显示为展开

时间:2015-06-12 18:07:56

标签: javascript jquery html frontend jquery-events

我想创建以下功能:

用户点击按钮(任何按钮都会这样做),将出现一个选择列表,其中所有选项都在按钮下方的向下滑动窗口内展开。

我知道如何制作幻灯片窗口以及所有这些,但我还没有找到任何有关如何使选择列表在点击事件中显示为扩展的信息。

棘手的部分是,我在CMS上下文中工作,我无法更改html,因此我必须实现仅使用jQuery的解决方案。

以下是表单的代码。



<p>Example Button (Could be any element outside the form)</p>

<form accept-charset="UTF-8" action="/accreditations" class="lang_dropdown_form language" id="lang_dropdown_form_language" method="post" name="lang_dropdown_form_language">
    <div>
        <img alt="English" class="language-icon" height="12" src="http://scsglobalservices_mobile_june.dd:8083/sites/all/modules/contrib/languageicons/flags/en.png" title="English" width="16">

        <div class="form-item form-type-select form-item-lang-dropdown-select">
            <div class="scs-select">
                <select class="lang-dropdown-select-element form-select" id="lang-dropdown-select-language" name="lang_dropdown_select" style="width:165px">
                    <option selected="selected" value="en">
                        English
                    </option>

                    <option value="de">
                        Deutsch
                    </option>

                    <option value="pt-br">
                        Português
                    </option>

                    <option value="es">
                        Espa├▒ol
                    </option>
                </select>
            </div>
        </div>
        <input name="en" type="hidden" value="/accreditations">
        <input name="de" type="hidden" value="/de/accreditations">
        <input name="pt-br" type="hidden" value="/pt-br/accreditations">
        <input name="es" type="hidden" value="/es/accreditations">
        <noscript>&lt;div&gt; &lt;input type="submit" id="edit-submit" name="op" value="Go" class="form-submit" /&gt; &lt;/div&gt;
        </noscript>
        <input name="form_build_id" type="hidden" value="form-IpZgiF0U6WXF2LbQDnlwtEw2rz1lh2s6DMwGFTeumzE">
        <input name="form_id" type="hidden" value="lang_dropdown_form">
    </div>
</form>
&#13;
&#13;
&#13;

2 个答案:

答案 0 :(得分:0)

这可行,但仅适用于Chrome。 jsFiddle

window.expand = function () { 
    var dropdown = document.getElementById('lang-dropdown-select-language');
    var event;
    event = document.createEvent('MouseEvents');
    event.initMouseEvent('mousedown', true, true, window);
    dropdown.dispatchEvent(event);
};

答案 1 :(得分:0)

这是一个想法 - 给你的lang-dropdown-select-language SELECT一个低z-index和CSS中的绝对位置。在你的javascript中,如果尚未设置,则将其大小设置为1:

($('#lang-dropdown-select-language').attr('size', value)

然后在你的javascript中创建一个具有更高z-index的新选择,display:none;并将大小设置为第一个选择中的选项数。将左侧和顶部设置为与第一个选择相同。将onchange事件附加到第二个事件。该函数应将1st 1st的selectedIndex设置为2nd的selectIndex,然后在2nd 2nd上切换display:none。

然后在你的按钮上点击你的按钮,通过设置display:block来显示第二个按钮;在代码中。

这个概念听起来有道理吗?