为什么这种排序功能不起作用?

时间:2015-03-18 21:39:21

标签: javascript jquery sorting

想要通过它的选项文本对html select进行排序。

$(function() {
        var options = $('#buybox select[name="group[2]"] option');

        var arr = options.map(function(_, o) {
            return {
                t: $(o).text(),
                v: o.value
            };
        }).get();

        arr.sort(function(a, b) {
            //return a.t > b.t ? 1 : a.t < b.t ? -1 : 0;// numeric
            var sizes = { "XS" : 0 , "S" : 1, "M" : 2, "L" : 3, "XL" : 4, "2XL" : 5};
            console.log(sizes);
            console.log(a.t);
            console.log(b.t);
            console.log(sizes[a.t]);
            console.log(sizes[b.t]);
            return sizes[a.t] > sizes[b.t] ? 1 : sizes[a.t] < sizes[b.t] ? -1 : 0;
        });

        options.each(function(i, o) {
            o.value = arr[i].v;
            $(o).text(arr[i].t);
        });


    });

数字排序工作正常。但属性名称a.t和b.t未定义。 这里有什么问题?

感谢

HTML选择

    select name="group[2]" onchange="this.form.submit();" style="width: 300px;">
<option selected="selected" value="7">L</option>
<option value="8">XL</option>
<option value="9">2XL</option>
<option value="35">M</option>
</select>

1 个答案:

答案 0 :(得分:0)

你让它变得复杂很多

var sizes  = ["XS", "S", "M", "L", "XL", "2XL"],
    select = $('#buybox select[name="group[2]"]');

$('option', select).sort(function (a, b) {
    return sizes.indexOf($(a).text()) - sizes.indexOf($(b).text());
}).appendTo(select);

FIDDLE