用于排列列表的排序逻辑

时间:2016-06-24 21:08:50

标签: html forms select html-lists html-table

我已经对排序做了一些更改,因为之前的逻辑只是将当前值与第一个索引值进行比较。我想与所有的价值观进行比较。

如果值为正值,请查看我刚刚编写的排序逻辑 请引导我           

<head>
    <script type="text/javascript" src="https://code.jquery.com/jquery-3.0.0.min.js"></script>
    <script>
    function myFunction() {
  var node = document.createElement("LI");
  var answer = document.getElementById("selectMe").value;
  var textboxvalue = document.getElementById("t1").value;
  if (answer == "positive") {
    var textnode = document.createTextNode(textboxvalue);
    node.appendChild(textnode);
    var p = document.getElementById("Positive").childNodes; // child Nodes of positive
  //sorting logic   
var p1= new array(100);
   p1=  document.getElementById("Positive").childNodes;
   var i;
var len= p1.length;
     for(i=0;i<len;i++){
     var preValue = p[i].innerHTML;
     if (preValue > textboxvalue) { // compare with previous positive value to insertbefore or append
        document.getElementById("Positive").insertBefore(node, p[1]);
      } else {
        document.getElementById("Positive").appendChild(node);
      }
     else {
      document.getElementById("Positive").appendChild(node);
    }    
      }
  } else if (answer == "negative") {
    var c = document.getElementById("negative").childNodes; // child Nodes of negative
    var textnode = document.createTextNode(textboxvalue);
    node.appendChild(textnode);

    if (c[1]) {
      var preValue = c[1].innerHTML;
      if (preValue > textboxvalue) { // compare with previous negative value to insertbefore or append
        document.getElementById("negative").insertBefore(node, c[1]);
      } else {
        document.getElementById("negative").appendChild(node);
      }
    } else {
      document.getElementById("negative").appendChild(node);
    }
  }

  //document.body.appendChild(node);
}

    </script>
</head>

<body>
    <h3> <strong> Javascript Test </strong></h3>
    <form name="myForm" id="myForm" method="post">
        <table>
            <tr>
                <td>
                    <label>Term: </label>
                </td>
                <td>
                    <input type="text" name="fname" id="t1"> </td>
            </tr>
            <br/>
            <tr>
                <td>
                    <label> Type:</label>
                </td>
                <td>
                    <select name="title" required id="selectMe">
                        <option value="">Choose:</option>
                        <option value="positive">Positive</option>
                        <option value="negative">Negative</option>
                    </select>
                    </select>
                </td>
                <tr>
                    <td>
                        <button onclick="myFunction()"> Onclick </button>
                    </td>
                </tr>
        </table>
    </form>
    <fieldset>
        <legend>See Result in this Section:</legend>
        <label> Positive </label>
        <ul id="Positive">
        </ul>
        <label> Negative </label>
        <ul id="negative">
        </ul>
    </fieldset>
    <script type="text/javascript">
        $("#myForm").submit(function(e) {
            e.preventDefault();
            if (validateForm()) {
                myFunction();
            }
        });
    </script>
</body>

</html>

1 个答案:

答案 0 :(得分:0)

遍历子元素数组并比较每个元素和insertBefore或附加元素

function myFunction() {
  var node = document.createElement("LI");
  var answer = document.getElementById("selectMe").value;
  var textboxvalue = document.getElementById("t1").value;
  if (answer == "positive") {
    var textnode = document.createTextNode(textboxvalue);
    node.appendChild(textnode);
    var p = document.getElementById("Positive").childNodes; // child Nodes of positive
    if (p[1]) {
      for (var i = 0; i < p.length; i++) {
        alert(i);
        var preValue = p[i].innerHTML;
        if (preValue > textboxvalue) { // compare with previous positive value to insertbefore or append
          document.getElementById("Positive").insertBefore(node, p[i]);
          break;
        } else {
          document.getElementById("Positive").appendChild(node);
        }
      }
    } else {
      document.getElementById("Positive").appendChild(node);
    }

  } else if (answer == "negative") {
    var c = document.getElementById("negative").childNodes; // child Nodes of negative
    var textnode = document.createTextNode(textboxvalue);
    node.appendChild(textnode);

    if (c[1]) {
      for (var i = 0; i < c.length; i++) {
        alert(i);
        var preValue = c[i].innerHTML;
        if (preValue > textboxvalue) { // compare with previous negative value to insertbefore or append
          document.getElementById("negative").insertBefore(node, c[i]);
          break;
        } else {
          document.getElementById("negative").appendChild(node);
        }
      }
    } else {
      document.getElementById("negative").appendChild(node);
    }
  }

  //document.body.appendChild(node);
}

http://codepen.io/nagasai/pen/ZOLyWZ