Форум АНТИЧАТ

Форум АНТИЧАТ (https://forum.antichat.xyz/index.php)
-   PHP, PERL, MySQL, JavaScript (https://forum.antichat.xyz/forumdisplay.php?f=37)
-   -   Javascript сортировка колонок талбицы. Помогите разобраться (https://forum.antichat.xyz/showthread.php?t=156641)

AARON 15.11.2009 06:14

Javascript сортировка колонок талбицы. Помогите разобраться
 
Откопал способ сортировки колонок отседава
http://htmlcoder.visions.ru/JavaScript/?22

PHP код:

<script type="text/javascript">
<!--
/*
originally written by paul sowden <paul@idontsmoke.co.uk> | http://idontsmoke.co.uk
modified and localized by alexander shurkayev <alshur@ya.ru> | 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 не предлагать. Это на крайний случай, если с джаваскриптом не разберусь ;)


Время: 18:40