将 optgroup 动态添加到现有选择

发布于 2025-01-16 09:20:02 字数 1556 浏览 0 评论 0原文

我有一个现有的选择,其中包含 5 个选项和一个默认的空白值。我想将一个 optgroup 添加到前 3 个值,并将另一个 optgroup 添加到最后两个选项。

<select id="cityDropdown">
    <option selected="selected" value="" label=" "> </option>
    <option value="1000">Tokyo</option>
    <option value="1001">Kyoto</option>
    <option value="1002">Osaka</option>
    <option value="1003">Incheon</option>
    <option value="1004">Busan</option>
</select>

我希望我的选择看起来像这样

<select id="cityDropdown">
    <optgroup label="Japan">
        <option value="1000">Tokyo</option>
        <option value="1001">Kyoto</option>
        <option value="1002">Osaka</option>
    </optgroup>
    <optgroup label="SoKorea">
        <option value="1003">Incheon</option>
        <option value="1004">Busan</option>
    </optgroup>
</select>

下面是我现有的代码,它不再有效,因为值不再均匀。

$(document).ready(function() {
    var select = $('#cityDropdown');
    var opt1, opt2;
    $('option', select).each(function(i) {
        if (i % 2 === 0) {
            opt1 = $(this);
        } else {
            opt2 = $(this);
            var optgroup = $('<optgroup/>');
            optgroup.attr('label', label);
            opt2.add(opt1).wrapAll(optgroup);
        }

    });
});

I have an existing select with 5 options and a default blank value. I want to add an optgroup to the first 3 values and another optgroup to the last two options.

<select id="cityDropdown">
    <option selected="selected" value="" label=" "> </option>
    <option value="1000">Tokyo</option>
    <option value="1001">Kyoto</option>
    <option value="1002">Osaka</option>
    <option value="1003">Incheon</option>
    <option value="1004">Busan</option>
</select>

I want my select to look like this

<select id="cityDropdown">
    <optgroup label="Japan">
        <option value="1000">Tokyo</option>
        <option value="1001">Kyoto</option>
        <option value="1002">Osaka</option>
    </optgroup>
    <optgroup label="SoKorea">
        <option value="1003">Incheon</option>
        <option value="1004">Busan</option>
    </optgroup>
</select>

Below is my existing code which no longer works since the values are no longer even.

$(document).ready(function() {
    var select = $('#cityDropdown');
    var opt1, opt2;
    $('option', select).each(function(i) {
        if (i % 2 === 0) {
            opt1 = $(this);
        } else {
            opt2 = $(this);
            var optgroup = $('<optgroup/>');
            optgroup.attr('label', label);
            opt2.add(opt1).wrapAll(optgroup);
        }

    });
});

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文