js實現table排序(jQuery下的jquery.sortElements)

來源:互聯網
上載者:User

標籤:stack   this   問題   網上   git   script   post   datatable   html   

項目中要實現table排序的功能。

網上有非常多解決方式,非常多都基於jQuery。

  • jquery.tablesorter。大小17KB。只是他的首頁在ie10下相容性有點問題。
  • DataTables,大小75KB。功能強大,帶分頁,搜尋等功能。

  • 還有外掛程式叫sortElements,非常小巧。僅僅有3KB。相容性也不錯。並且在Github上有818個星。

最後我選擇用sortElements,實現非常easy:

1. 引入jQuery

<script type="text/javascript" src="jquery.js"></script>  

2. 引入sortElements.js

<script type="text/javascript" src="jquery.sortElements.js"></script>  

3. js 代碼

    $(document).ready(function(){         var table = $(‘#mytable‘);//table的id       $(‘#sort_header‘)//要排序的headerid        .each(function(){            var th = $(this),                thIndex = th.index(),                inverse = false;                        th.click(function(){                table.find(‘td‘).filter(function(){                    return $(this).index() === thIndex;                }).sortElements(function(a, b){                    return $.text([a]) > $.text([b]) ?

inverse ? -1 : 1 : inverse ?

1 : -1; }, function(){ return this.parentNode; }); inverse = !inverse; }); });});


4. html代碼

<table id="mytable">    <tr>        <th id="sort_header">Facility name</th>        <th>Phone #</th>        <th id="city_header">City</th>        <th>Speciality</th>    </tr>    <tr>        <td>CCC</td>        <td>00001111</td>        <td>Amsterdam</td>        <td>GGG</td>    </tr>...</table>


實現效果:www.bishouyi.cn

(由padolsey開發,github地址為https://github.com/padolsey/jquery.fn/tree/master/sortElements)

參考:http://stackoverflow.com/questions/3160277/jquery-table-sort


js實現table排序(jQuery下的jquery.sortElements)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.