Javascript сортировка колонок талбицы. Помогите разобраться

Discussion in 'PHP' started by AARON, 15 Nov 2009.

  1. AARON

    AARON Elder - Старейшина

    Joined:
    29 Apr 2008
    Messages:
    62
    Likes Received:
    14
    Reputations:
    1
    Откопал способ сортировки колонок отседава
    http://htmlcoder.visions.ru/JavaScript/?22

    PHP:
    <script type="text/javascript">
    <!--
    /*
    originally written by paul sowden <[email protected]> | http://idontsmoke.co.uk
    modified and localized by alexander shurkayev <[email protected]> | http://htmlcoder.visions.ru
    */

    var img_dir "/i/"// папка с картинками
    var sort_case_sensitive false// вид сортировки (регистрозависимый или нет)

    // ф-ция, определяющая алгоритм сортировки
    function _sort(ab) {
        var 
    a[0];
        var 
    b[0];
        var 
    _a = ('').replace(/,/, '.');
        var 
    _b = ('').replace(/,/, '.');
        if (
    parseFloat(_a) && parseFloat(_b)) return sort_numbers(parseFloat(_a), parseFloat(_b));
        else if (!
    sort_case_sensitive) return sort_insensitive(ab);
        else return 
    sort_sensitive(ab);
    }

    // ф-ция сортировки чисел
    function sort_numbers(ab) {
        return 
    b;
    }

    // ф-ция регистронезависимой сортировки
    function sort_insensitive(ab) {
        var 
    anew a.toLowerCase();
        var 
    bnew b.toLowerCase();
        if (
    anew bnew) return -1;
        if (
    anew bnew) return 1;
        return 
    0;
    }

    // ф-ция регистрозависимой сортировки
    function sort_sensitive(ab) {
        if (
    b) return -1;
        if (
    b) return 1;
        return 
    0;
    }

    // вспомогательная ф-ция, выдирающая из дочерних узлов весь текст
    function getConcatenedTextContent(node) {
        var 
    _result "";
        if (
    node == null) {
            return 
    _result;
        }
        var 
    childrens node.childNodes;
        var 
    0;
        while (
    childrens.length) {
            var 
    child childrens.item(i);
            switch (
    child.nodeType) {
                case 
    1// ELEMENT_NODE
                
    case 5// ENTITY_REFERENCE_NODE
                    
    _result += getConcatenedTextContent(child);
                    break;
                case 
    3// TEXT_NODE
                
    case 2// ATTRIBUTE_NODE
                
    case 4// CDATA_SECTION_NODE
                    
    _result += child.nodeValue;
                    break;
                case 
    6// ENTITY_NODE
                
    case 7// PROCESSING_INSTRUCTION_NODE
                
    case 8// COMMENT_NODE
                
    case 9// DOCUMENT_NODE
                
    case 10// DOCUMENT_TYPE_NODE
                
    case 11// DOCUMENT_FRAGMENT_NODE
                
    case 12// NOTATION_NODE
                // skip
                
    break;
            }
            
    i++;
        }
        return 
    _result;
    }

    // суть скрипта
    function sort(e) {
        var 
    el window.event window.event.srcElement e.currentTarget;
        while (
    el.tagName.toLowerCase() != "td"el el.parentNode;
        var 
    = new Array();
        var 
    name el.lastChild.nodeValue;
        var 
    dad el.parentNode;
        var 
    table dad.parentNode.parentNode;
        var 
    up table.up;
        var 
    nodearrowcurcol;
        for (var 
    0; (node dad.getElementsByTagName("td").item(i)); i++) {
            if (
    node.lastChild.nodeValue == name){
                
    curcol i;
                if (
    node.className == "curcol"){
                    
    arrow node.firstChild;
                    
    table.up Number(!up);
                }else{
                    
    node.className "curcol";
                    
    arrow node.insertBefore(document.createElement("img"),node.firstChild);
                    
    table.up 0;
                }
                
    arrow.src img_dir table.up ".gif";
                
    arrow.alt "";
            }else{
                if (
    node.className == "curcol"){
                    
    node.className "";
                    if (
    node.firstChildnode.removeChild(node.firstChild);
                }
            }
        }
        var 
    tbody table.getElementsByTagName("tbody").item(0);
        for (var 
    0; (node tbody.getElementsByTagName("tr").item(i)); i++) {
            
    a[i] = new Array();
            
    a[i][0] = getConcatenedTextContent(node.getElementsByTagName("td").item(curcol));
            
    a[i][1] = getConcatenedTextContent(node.getElementsByTagName("td").item(1));
            
    a[i][2] = getConcatenedTextContent(node.getElementsByTagName("td").item(0));
            
    a[i][3] = node;
        }
        
    a.sort(_sort);
        if (
    table.upa.reverse();
        for (var 
    0a.lengthi++) {
            
    tbody.appendChild(a[i][3]);
        }
    }

    // ф-ция инициализации всего процесса
    function init(e) {
        if (!
    document.getElementsByTagName) return;

        for (var 
    0; (thead document.getElementsByTagName("thead").item(j)); j++) {
            var 
    node;
            for (var 
    0; (node thead.getElementsByTagName("td").item(i)); i++) {
                if (
    node.addEventListenernode.addEventListener("click"sortfalse);
                else if (
    node.attachEventnode.attachEvent("onclick"sort);
                
    node.title "Нажмите на заголовок, чтобы отсортировать колонку";
            }
            
    thead.parentNode.up 0;
            
            if (
    typeof(initial_sort_id) != "undefined"){
                
    td_for_event thead.getElementsByTagName("td").item(initial_sort_id);
                if (
    document.createEvent){
                    var 
    evt document.createEvent("MouseEvents");
                    
    evt.initMouseEvent("click"falsefalsewindow1000000001td_for_event);
                    
    td_for_event.dispatchEvent(evt);
                } else if (
    td_for_event.fireEventtd_for_event.fireEvent("onclick");
                if (
    typeof(initial_sort_up) != "undefined" && initial_sort_up){
                    if (
    td_for_event.dispatchEventtd_for_event.dispatchEvent(evt);
                    else if (
    td_for_event.fireEventtd_for_event.fireEvent("onclick");
                }
            }
        }
    }

    // запускаем ф-цию init() при возникновении события load
    var root window.addEventListener || window.attachEvent window document.addEventListener document null;
    if (
    root){
        if (
    root.addEventListenerroot.addEventListener("load"initfalse);
        else if (
    root.attachEventroot.attachEvent("onload"init);
    }
    //-->
    </script>
    Мне необходимо сортировать колонку с датами такого вида

    За 10.09.2009
    За 11.11.2009
    За 15.10.2009
    За 14.10.2009

    но, как не сложно догадаться, скрипт сортирует по числу, плюя на месяц и на год, тобишь:

    За 10.09.2009
    За 11.11.2009
    За 14.10.2009
    За 15.10.2009


    Помогите разобраться с сортировкой даты. mysql ORDER BY date DESC не предлагать. Это на крайний случай, если с джаваскриптом не разберусь ;)