ANTICHAT.XYZ    VIDEO.ANTICHAT.XYZ    НОВЫЕ СООБЩЕНИЯ    ФОРУМ  
Баннер 1   Баннер 2
Antichat снова доступен.
Форум Antichat (Античат) возвращается и снова открыт для пользователей. Здесь обсуждаются безопасность, программирование, технологии и многое другое. Сообщество снова собирается вместе.
Новый адрес: forum.antichat.xyz
Вернуться   Форум АНТИЧАТ > Программирование > PHP, PERL, MySQL, JavaScript
   
Ответ
 
Опции темы Поиск в этой теме Опции просмотра

Javascript сортировка колонок талбицы. Помогите разобраться
  #1  
Старый 15.11.2009, 06:14
Аватар для AARON
AARON
Участник форума
Регистрация: 29.04.2008
Сообщений: 106
Провел на форуме:
647733

Репутация: 46
По умолчанию 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 не предлагать. Это на крайний случай, если с джаваскриптом не разберусь
 
Ответить с цитированием
Ответ



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Помогите разобраться с TidHttp narik_ С/С++, C#, Delphi, .NET, Asm 13 11.08.2009 15:03
Помогите разобраться.... DarkMist PHP, PERL, MySQL, JavaScript 2 04.01.2009 03:15
Помогите разобраться с угоном Аськи seeattact ICQ 5 17.01.2006 03:14
Bypassing JavaScript Filters the Flash! Attack k00p3r Чужие Статьи 0 12.07.2005 16:11



Здесь присутствуют: 1 (пользователей: 0 , гостей: 1)
 


Быстрый переход




ANTICHAT.XYZ