jQuery 使用数据 id 对元素进行排序

IT技术 javascript jquery html sorting
2021-03-03 18:20:46

我有一个 HTML 结构如下:

<div class="clist">
    <div data-sid=1></div>
    <div data-sid=2></div>
    <div data-sid=2></div>
    <div data-sid=1></div>
    <div data-sid=2></div>
    <div data-sid=2></div>
    <div data-sid=1></div>
</div>

我想将它们排序为:

<div class="clist">
    <div data-sid=1></div>
    <div data-sid=1></div>
    <div data-sid=1></div>
    <div data-sid=2></div>
    <div data-sid=2></div>
    <div data-sid=2></div>
    <div data-sid=2></div>
</div>

我正在使用以下功能:

function sortContacts() {
    var contacts = $('div.clist'), cont = contacts.children('div');

    cont.detach().sort(function(a, b) {
        var astts = $(a).data('sid');
        var bstts = $(b).data('sid')
        return (astts > bstts) ? (astts > bstts) ? 1 : 0 : -1;
    });

    contacts.append(cont);
}

它没有按预期工作。

它在第一次运行时运行良好,但在添加新元素或更改data-sid属性后,它不再起作用。

演示:http : //jsfiddle.net/f5mC9/1/

不工作?

4个回答

您可以使用dataset存储data-*元素的所有自定义属性的属性,它返回一个字符串,以防您想将字符串转换为您可以使用的数字parseInt+运算符。

$('.clist div').sort(function(a,b) {
     return a.dataset.sid > b.dataset.sid;
}).appendTo('.clist');

http://jsfiddle.net/CFYnE/

是的,你的代码在这里工作,http://jsfiddle.net/f5mC9/

编辑:请注意IE10!及以下不支持该.dataset属性,如果你想支持所有浏览器你可以使用jQuery的.data()方法代替:

$('.clist div').sort(function(a,b) {
     return $(a).data('sid') > $(b).data('sid');
}).appendTo('.clist');
我在按字符串值对超过 10 个的列表进行排序时遇到了问题。我不得不将比较更改为: return a.dataset.sid > b.dataset.sid ?1 : (a.dataset.sid < b.dataset.sid ? -1 : 0);
2021-04-23 18:20:46
@trincot 这是一个很好的观点。需要注意的是,jQuery.data()尝试将data-*属性解析为 JSON,因此字符串化的数字会被 jQuery 强制转换为实数。
2021-05-02 18:20:46
奇迹般有效!谢谢!
2021-05-04 18:20:46
请注意,.data()用于访问 HTML 数据属性会在第一次访问时创建数据属性的副本。如果稍后更改数据属性的值,data()仍将返回旧值。
2021-05-06 18:20:46
我不能.data()在 IE11 或 Edge 中工作。:( jsfiddle.net/4o771n7o
2021-05-09 18:20:46
$('.clist div').sort(function(a,b) {
     return parseInt(a.dataset.sid) - parseInt(b.dataset.sid);
}).appendTo('.clist');

使用 jQuery 对元素进行排序的更通用的函数:

$.fn.sortChildren = function (sortingFunction: any) {

    return this.each(function () {
        const children = $(this).children().get();
        children.sort(sortingFunction);
        $(this).append(children);
    });

};

用法:

$(".clist").sortChildren((a, b) => a.dataset.sid > b.dataset.sid ? 1 : -1);

function orderSteps() {
    var steps = $('div.steps'),
        cont = steps.children('div.step');
    cont.detach().sort(function (a, b) {
        var astts = a;
        var bstts = b;

        // stripping the id to get the position number
        var classArrA = $(astts).attr("id").split("-")[1];
        var classArrB = $(bstts).attr("id").split("-")[1];

        // checking for the greater position and order accordingly
        if (parseInt(classArrA) > parseInt(classArrB)) {
            return (0)
        }
        else {
            return (-1)
        }
    })
    steps.append(cont);
};

orderSteps()
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="container-fluid steps">
            <div class="row text-center border-bottom step" id="step-1">
                <span class="col-3">Item 1</span>
            </div>
            <div class="row text-center border-bottom step" id="step-2">
                <span class="col-3">Item 2</span>
            </div>
            <div class="row text-center border-bottom step" id="step-30">
                <span class="col-3">Item 3</span>
            </div>
            <div class="row text-center border-bottom step" id="step-4">
                <span class="col-3">Item 4</span>
            </div>
        </div>