>웹 프론트엔드 >JS 튜토리얼 >요소 순서 일관성을 유지하기 위해 JavaScript에서 안정적인 정렬을 수행하는 방법은 무엇입니까?

요소 순서 일관성을 유지하기 위해 JavaScript에서 안정적인 정렬을 수행하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-10-18 20:42:03629검색

How to Perform Stable Sorting in JavaScript to Maintain Element Order Consistency?

JavaScript의 안정적인 정렬 알고리즘

데이터를 정렬할 때 동일한 요소의 원래 순서를 유지하는 것이 안정적인 정렬 알고리즘을 위해 중요합니다. 이러한 맥락에서 우리는 요소 순서 일관성을 유지하면서 특정 키를 가진 객체 배열을 주어진 순서로 정렬하는 것을 목표로 합니다.

안정적인 정렬 기술

흥미롭게도 불안정한 정렬 기능을 사용하면 안정적인 정렬이 가능합니다. 정렬하기 전에 각 요소의 초기 위치를 캡처하면 위치를 보조 기준으로 사용하여 정렬 비교에서 동점을 끊을 수 있습니다.

JavaScript로 구현

<code class="javascript">const sortBy = (arr, key, order) => {
  // Capture element positions
  const positions = arr.map((item, i) => {
    return { item, position: i };
  });

  // Perform sorting
  positions.sort((a, b) => {
    let cmp = a.item[key].localeCompare(b.item[key]);
    if (cmp === 0) {
      // Tiebreaker: sort by position
      cmp = a.position - b.position;
    }
    if (order === "desc") {
      return cmp * -1;
    } else {
      return cmp;
    }
  });

  // Return sorted objects
  return positions.map(position => position.item);
};</code>

사용 예

<code class="javascript">const data = [
  { name: "Alice", age: 25 },
  { name: "Bob", age: 30 },
  { name: "Eve", age: 25 },
];

const sortedAscending = sortBy(data, "age", "asc");
console.log(sortedAscending); // [{ name: "Alice", age: 25 }, { name: "Eve", age: 25 }, { name: "Bob", age: 30 }]

const sortedDescending = sortBy(data, "age", "desc");
console.log(sortedDescending); // [{ name: "Bob", age: 30 }, { name: "Eve", age: 25 }, { name: "Alice", age: 25 }]</code>

이 기술을 사용하면 동일한 값을 가진 요소의 원래 순서를 유지하면서 JavaScript에서 안정적인 정렬이 가능합니다.

위 내용은 요소 순서 일관성을 유지하기 위해 JavaScript에서 안정적인 정렬을 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.