前端實現list排序


需求

  • 針對list中某個字段,實現list的升序和降序

效果圖

代碼

我是用在angular1.X中項目的,根據list中的sort字段進行排序。

# sort.html
<style>
.list-sort .upper-sort {
  width: 0;
  height: 0;
  margin-bottom: 10px;
  border-top: 15px solid transparent;
  border-right: 15px solid transparent;
  border-bottom: 15px solid #ccc;
  border-left: 15px solid transparent;
}

.list-sort .down-sort {
  width: 0;
  height: 0;
  border-top: 15px solid #ccc;
  border-right: 15px solid transparent;
  border-bottom: 15px solid transparent;
  border-left: 15px solid transparent;
}
</style>

...

<div class="list-sort">
  <div class="upper-sort" data-action="upper" ng-click="upSort()"></div>
  <div class="down-sort" data-action="down" ng-click="downSort()"></div>
</div>

#sortCtrl.js
function bubble_sort(list) {
  count = list.length;
  for (let i = 0;i < count - 1;i++) {
      let swapped = false;
      for (let j = 0;j < count - 1;j++) {
          if (list[j].score > list[j + 1].score) {
              let temp = list[j];
              list[j] = list[j + 1];
              list[j + 1] = temp;
              swapped = true;
          }
      }
      if (!swapped) {
          break;
      }
  }
  return list;
}

function bubble_sort_revert(list) {
  count = list.length;
  for (let i = 0;i < count - 1;i++) {
      let swapped = false;
      for (let j = 0;j < count - 1;j++) {
          if (list[j].score < list[j + 1].score) {
              let temp = list[j];
              list[j] = list[j + 1];
              list[j + 1] = temp;
              swapped = true;
          }
      }
      if (!swapped) {
          break;
      }
  }
  return list;
}

$scope.upSort = function () {
  bubble_sort($scope.candidateList)
  let upper = document.querySelector("[data-action=upper]");
  let down = document.querySelector("[data-action=down]");
  upper.style.borderBottomColor = "#2196f3";
  down.style.borderTopColor = "#ccc";
};

$scope.downSort = function () {
  bubble_sort_revert($scope.candidateList)
  let upper = document.querySelector("[data-action=upper]");
  let down = document.querySelector("[data-action=down]");
  upper.style.borderBottomColor = "#ccc";
  down.style.borderTopColor = "#2196f3";
};


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM