Go Back   CodingForums.com > :: Client side development > JavaScript programming > Post a JavaScript

Before you post, read our: Rules & Posting Guidelines

Reply
 
Thread Tools Rate Thread
Enjoy an ad free experience by logging in. Not a member yet? Register.
Old 04-12-2012, 11:15 AM   PM User | #1
hgs
New Coder

 
Join Date: Jan 2010
Location: Germany
Posts: 52
Thanks: 1
Thanked 2 Times in 2 Posts
hgs is on a distinguished road
Simple way to sort a table

Below is just another simple way to sort a table;
A working page can be found at
http://www.hgsweb.de/tablesort/




Code:
<!DOCTYPE html>
<html>
    <head>
        <title></title>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <script type="text/javascript">  
            function sortUp(col){
                var t=document.getElementById('s');
                var first=true,prevref,nr=t.rows.length;
                var ih,r1,r2,k,i,ref,ref1,j,sw,nc=t.rows[0].cells.length;
   
                for(i=0;i<nr;i++){
                    if(t.rows[i].cells[col].tagName!=='TD'){
                        continue;
                    }
                    ref=t.rows[i].cells[col].textContent;
                    for(j=i+1,sw=-1,first=true;j<nr;j++){
                        if(t.rows[j].cells[col].tagName!=='TD'){
                            continue;
                        }
                        ref1=t.rows[j].cells[col].textContent;
                        if(ref1<ref){                 
                            if(first){ 
                                prevref=ref1;
                                first=false;
                                sw=j;
                            } else{
                                if(ref1<prevref){
                                    prevref=ref1;
                                    sw=j                          
                                }
                            }              
                        }
                    }
                    if(sw>0){                            
                        r1=t.rows[i].cells;
                        r2=t.rows[sw].cells;
                        for(k=0;k<nc;k++){
                            ih=r1[k].innerHTML;
                            r1[k].innerHTML=r2[k].innerHTML;
                            r2[k].innerHTML=ih;  
                        }
                    }
                }
            }
            function sortDown(col){
                var t=document.getElementById('s');
                var first=true,prevref,nr=t.rows.length;
                var ih,r1,r2,k,i,ref,ref1,j,sw,nc=t.rows[0].cells.length;
   
                for(i=0;i<nr;i++){
                    if(t.rows[i].cells[col].tagName!=='TD'){
                        continue;
                    }
                    ref=t.rows[i].cells[col].textContent;
                    for(j=i+1,sw=-1,first=true;j<nr;j++){
                        if(t.rows[j].cells[col].tagName!=='TD'){
                            continue;
                        }
                        ref1=t.rows[j].cells[col].textContent;
                        if(ref1>ref){                 
                            if(first){ 
                                prevref=ref1;
                                first=false;
                                sw=j;
                            } else{
                                if(ref1>prevref){
                                    prevref=ref1;
                                    sw=j                          
                                }
                            }              
                        }
                    }
                    if(sw>0){                            
                        r1=t.rows[i].cells;
                        r2=t.rows[sw].cells;
                        for(k=0;k<nc;k++){
                            ih=r1[k].innerHTML;
                            r1[k].innerHTML=r2[k].innerHTML;
                            r2[k].innerHTML=ih;  
                        }
                    }
                }
            }
        </script>
    </head>
    <body>
        <pre>
Very simple way to sort a table just by  comparing
the textContent of table cells. 
Once rows must be swapped , only the innerHTML of their cells will be swapped.
In the source of this page you will find the scripts 
        </pre>    
        
        <table id="s" border="1">
            <tr><th>Colum 0 <img src="sort-up.gif" onclick="sortUp(0);"><img src="sort-down.gif" onclick="sortDown(0);"></th>
                <th>Colum 1 <img src="sort-up.gif" onclick="sortUp(1);"><img src="sort-down.gif" onclick="sortDown(1);"></th>
                <th>Colum 2 <img src="sort-up.gif" onclick="sortUp(2);"><img src="sort-down.gif" onclick="sortDown(2);"></th></tr>
            <tr><td>5</td><td>7</td><td>1</td></tr>
            <tr><td>88</td><td>6</td><td>7</td></tr>
            <tr><td>3</td><td>0</td><td>77</td></tr>
            <tr><td>5</td><td>7</td><td>1</td></tr>
            <tr><td>88</td><td>6</td><td>7</td></tr>
            <tr><td>3</td><td>0</td><td>77</td></tr>
            <tr><td>A</td><td>7</td><td>1</td></tr>
            <tr><td>88</td><td>6</td><td>7</td></tr>
            <tr><td>3</td><td>0</td><td>77</td></tr>
            <tr><td>5</td><td>7</td><td>1</td></tr>
            <tr><td>88</td><td>6</td><td>7</td></tr>
            <tr><th>ZZZ</th><th>CCC</th><th>AAA</th></tr>
            <tr><td>5</td><td>7</td><td>1</td></tr>
            <tr><td>88</td><td>6</td><td>7</td></tr>
            <tr><td>3</td><td>0</td><td>77</td></tr>
            <tr><td>5</td><td>7</td><td>1</td></tr>
            <tr><td>88</td><td>6</td><td>7</td></tr>
            <tr><td>b</td><td>0</td><td>77</td></tr>
            <tr><td>5</td><td>7</td><td>1</td></tr>
            <tr><td>88</td><td>6</td><td>7</td></tr>
            <tr><td>!</td><td>0</td><td>77</td></tr>
        </table>
    </body>
</html>
hgs is offline   Reply With Quote
Reply

Bookmarks

Tags
sort

Jump To Top of Thread


Thread Tools
Rate This Thread
Rate This Thread:

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is Off
HTML code is Off

Forum Jump


All times are GMT +1. The time now is 08:52 PM.


Advertisement
Log in to turn off these ads.