1

我正在尝试对选项进行排序,multiselect而忽略了这种情况。我已经看到了分别做这些事情的方法,但我不确定如何一起做。

这是我用于排序的 HTML:

<form action="" method="get">
<label for="elliot">select:</label>
<select name="elliot" multiple="multiple" id="elliot1" style="height:140px;display:block;width: 200px;">
<option>d</option>
<option>Z</option>
<option>avery</option>
<option>5</option>
<option>Alive</option>
<option>8</option>
<option>b</option>
</select>
<button type="button" onclick="javascript:sortSelect(elliot1);">Sort</button>
</form>

这是我的 JavaScript(注意:我不是在寻找 jQuery 解决方案):

function sortSelect(selElem) {
    var tmpAry = new Array();
    for (var i=0;i<selElem.options.length;i++) {
        tmpAry[i] = new Array();
        //tmpAry[i][0] = selElem.options[i].text;
        tmpAry[i][0] = selElem.options[i].text;
        tmpAry[i][1] = selElem.options[i].value;
    }
    tmpAry.sort();
    while (selElem.options.length > 0) {
        selElem.options[0] = null;
    }
    for (var i=0;i<tmpAry.length;i++) {
        var op = new Option(tmpAry[i][0], tmpAry[i][1]);
        selElem.options[i] = op;
    }
    return;
}

这是jsFiddle

4

1 回答 1

2

您应该像这样覆盖默认排序功能:

tmpAry.sort(
  function (a, b) {
    var _a = a[0].toLowerCase();
    var _b = b[0].toLowerCase();
    if (_a < _b) return -1;
    if (_a > _b) return 1;
    return 0;
});

小提琴

这是 ECMAScript Array.sort的一般形式:

function compare(a, b) {
  if (a is less than b by some ordering criterion)
     return -1;
  if (a is greater than b by the ordering criterion)
     return 1;
  // a must be equal to b
  return 0;
}
于 2013-06-11T19:16:36.540 回答