JavaScript/jQuery: Reorder input/textarea by value

Using JavaScript / jQuery, how can I sort a group of an input and a textarea by the value of the textarea?

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Demo</title>

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.min.js"></script>
<script type="text/javascript">

$(document).ready(function() {

 $('#alpha').click(function() {
  alert("Change Order to Apple, Peach, Zoo");
 });

});

</script>
</head>
<body>


<div id="fields">
    <p class="item">
        <a class="itemDown"></a>
        <a class="itemUp first"></a>
        <input autocomplete="off" name="Text_healthcare_Client_List_xa0" value="2400195" type="text"><br />
        <textarea rows="9" cols="99" name="Text_healthcare_Client_List_xb0">Zoo</textarea><hr />
    </p>
    <p class="item">
        <a class="itemRemove"></a>
        <a class="itemDown"></a>
        <a class="itemUp"></a>
        <input autocomplete="off" name="Text_healthcare_Client_List_xa1" value="2402014" type="text"><br />
        <textarea rows="9" cols="99" name="Text_healthcare_Client_List_xb1">Apple</textarea><hr />
    </p>
    <p class="item">
        <a class="itemRemove"></a>
        <a class="itemDown"></a>
        <a class="itemUp"></a>
        <input autocomplete="off" name="Text_healthcare_Client_List_xa2" value="2400173" type="text"><br />
        <textarea rows="9" cols="99" name="Text_healthcare_Client_List_xb2">Peach</textarea><hr />
    </p>
</div>

<input type="button" id="alpha" value="Sort" />

</body>
</html>

Open in new window

LVL 16
hankknightAsked:
Who is Participating?
 
leakim971Connect With a Mentor PluritechnicianCommented:
Test page : http://jsfiddle.net/Kp9FD/
Using :
$(document).ready(function() {

 $('#alpha').click(function() {
     $(".item").each(function() {
         sortDem($(this).prevAll(".item:eq(0)"), $(this))
     })
 });

});

function sortDem(prev, curr) {
    if(prev.length>0) {
        var pVal = $("textarea", prev).val();
        var cVal = $("textarea", curr).val();
        if(pVal>cVal) {
            curr.insertBefore(prev);
            sortDem(curr.prevAll(".item:eq(0)"), curr); 
        }
    }
}

Open in new window

0
 
hankknightAuthor Commented:
Thanks!  I modified your code slightly to make it case-insensitive.


function sortDem(prev, curr) {
    if(prev.length>0) {
        var pVal = $("textarea", prev).val().toLowerCase().trim();
        var cVal = $("textarea", curr).val().toLowerCase().trim();
        if(pVal>cVal) {
            curr.insertBefore(prev);
            sortDem(curr.prevAll(".item:eq(0)"), curr); 
        }
    }
}

Open in new window

0
 
leakim971PluritechnicianCommented:
0
 
hankknightAuthor Commented:
Ooops, the order is not preserved when the form is submitted.  I asked a related question here:
http://www.experts-exchange.com/Programming/Languages/Scripting/JavaScript/Jquery/Q_28021103.html
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.