国家/地区的Select2下拉列表,带有标记

时间:2013-08-07 09:15:24

标签: javascript jquery-select2

对于Select2,某人是否有一个易于使用的国家/地区下拉列表示例?我即将根据this建议实施一个,但我宁愿避免重新发明轮子。

4 个答案:

答案 0 :(得分:10)

我正在研究类似的问题,这就是我如何解决它。

(function($) {
    $(function() {
        var isoCountries = [
            { id: 'AF', text: 'Afghanistan'},
            ...
        ];
        //Assuming you have a select element with name country
        // e.g. <select name="name"></select>

        $("[name='country']").select2({
            placeholder: "Select a country",
            data: isoCountries
        });
    });
})(jQuery);

我也有一个关于它的gist,以下是演示。

答案 1 :(得分:5)

我这样做的方式:

<div class="form-group">
    <label class="control-label">Destination</label>
    <input type="text" name="cdCountry" class="form-control" required />
</div>

<script>
    $("[name='cdCountry']").select2({
        placeholder: "Select a country",
        formatResult: function (country) {
            return $(
              "<span><i class=\"flag flag-" + country.id.toLowerCase() + "\"></i> " + country.text + "</span>"
            );;
        },
        data: yourDataSource
    });
</script>

并使用css库(css和sprite) https://www.flag-sprites.com/

Official DOC

答案 2 :(得分:2)

答案 3 :(得分:1)

<head>
    <link href="select2.css" rel="stylesheet"/>
    <script src="select2.js"></script>
    <script>
        $(document).ready(function() { $("#e1").select2(); });
    </script>
</head>
<body>
    <select id="e1">
        <option value="1">Albania<img src="Albania.jpg"></option>
        ...
        <option value="2">Germany<img src="Germany.jpg"></option>
    </select>
</body>