자바스크립트 sort()를 이용한 숫자 정렬

· 18년 전 · 4377
자바스크립트에서 sort는 기본적으로 아스키값을 기준으로 정렬합니다.

그래서 2보다 10이 앞에 오죠.


숫자 정렬되게 sort용 함수를 만들어봤습니다.

# 음수는 -가 제일 앞에 와야 제대로 정렬합니다.
뒤에 붙으면 문자로서의 -와 기능적으로 구분하기가 거의 불가능하므로 그냥 문자 취급합니다.


function sort2(a,b)
{
    if(parseInt(a) > parseInt(b)) return 1;
    else if(parseInt(a) < parseInt(b)) return -1;
    else
    {
        var sort = new Array(a,b);
        sort.sort();
        return (sort[0] == a)?-1:1;
    }
}

간단하게 했지만, 문자 뒤에 오는 숫자는 역시 제대로 정렬되지 않습니다.

아래는 문자 뒤의 숫자도 정렬하게 만든 것.


function sort(a,b)
{
    aS = a.toString(10).toUpperCase();
    bS = b.toString(10).toUpperCase();
    if(aS == bS) return 0;

    while(aS || bS)
    {
        aS = aS.replace(/^((\-?\d*)[^\d]*)/,"");
        aT = RegExp.$1;
        aN = RegExp.$2;

        bS = bS.replace(/^((\-?\d*)[^\d]*)/,"");
        bT = RegExp.$1;
        bN = RegExp.$2;
    
        if(aN && bN && aN != bN) return Number(aN)>Number(bN)?1:-1;
        else if(aT != bT)
        {
            var sort = new Array(aT,bT);
            sort.sort();
            return (sort[0] == aT)?-1:1;
        }
    }
}

덧붙여서 대소문자 구분하지 않고 정렬합니다.
[이 게시물은 관리자님에 의해 2011-10-31 16:57:14 JavaScript에서 이동 됨]
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

태그 필터 (최대 3개) 전체 개발자 소스 기타 mysql 팁자료실 javascript php linux flash 정규표현식 jquery node.js mobile 웹서버 os 프로그램 강좌 썸네일 이미지관련 도로명주소 그누보드5 기획자 견적서 계약서 기획서 마케팅 제안서 seo 통계 서식 통계자료 퍼블리셔 html css 반응형 웹접근성 퍼블리싱 표준화 반응형웹 홈페이지기초 부트스트랩 angularjs 포럼 스크린리더 센스리더 개발자톡 개발자팁 퍼블리셔톡 퍼블리셔팁 기획자톡 기획자팁 프로그램강좌 퍼블리싱강좌
+
제목 글쓴이 날짜 조회
18년 전 조회 5,554
18년 전 조회 3,267
18년 전 조회 2,832
18년 전 조회 3,497
18년 전 조회 2,704
18년 전 조회 3,070
18년 전 조회 6,091
18년 전 조회 2,849
18년 전 조회 2,224
18년 전 조회 2,866
18년 전 조회 1,696
18년 전 조회 1만
18년 전 조회 4,686
18년 전 조회 3,510
18년 전 조회 2,035
18년 전 조회 3,823
18년 전 조회 2,507
18년 전 조회 3,954
18년 전 조회 5,381
18년 전 조회 4,042
18년 전 조회 2,903
18년 전 조회 3,181
18년 전 조회 2,672
18년 전 조회 3,001
18년 전 조회 2,121
18년 전 조회 3,670
18년 전 조회 2,357
18년 전 조회 2,493
18년 전 조회 2,301
18년 전 조회 3,276
18년 전 조회 2,215
18년 전 조회 2,892
18년 전 조회 4,076
18년 전 조회 4,794
18년 전 조회 2,590
18년 전 조회 3,080
18년 전 조회 4,842
18년 전 조회 2,907
18년 전 조회 2,081
18년 전 조회 3,544
18년 전 조회 3,347
18년 전 조회 4,065
18년 전 조회 2,410
18년 전 조회 2,556
18년 전 조회 1만
18년 전 조회 3,736
18년 전 조회 3,529
18년 전 조회 3,408
18년 전 조회 3,028
18년 전 조회 4,378
18년 전 조회 5,716
18년 전 조회 3,970
18년 전 조회 3,418
18년 전 조회 3,839
18년 전 조회 2,482
18년 전 조회 2,909
18년 전 조회 4,154
18년 전 조회 3,076
18년 전 조회 4,575
18년 전 조회 2,300
18년 전 조회 2,729
18년 전 조회 2,641
18년 전 조회 4,015
18년 전 조회 4,068
18년 전 조회 2,797
18년 전 조회 2,877
18년 전 조회 3,190
18년 전 조회 3,021
18년 전 조회 2,243
18년 전 조회 2,406
18년 전 조회 5,055
18년 전 조회 4,409
18년 전 조회 3,035
18년 전 조회 2,572
18년 전 조회 3,090
18년 전 조회 2,561
18년 전 조회 3,732
18년 전 조회 2,401
18년 전 조회 2,180
18년 전 조회 2,060
18년 전 조회 1,874
18년 전 조회 3,438
18년 전 조회 4,772
18년 전 조회 5,048
18년 전 조회 2,340
18년 전 조회 3,807
18년 전 조회 3,513
18년 전 조회 4,795
18년 전 조회 3,463
18년 전 조회 4,448
18년 전 조회 4,132
18년 전 조회 3,822
18년 전 조회 3,236
18년 전 조회 3,112
18년 전 조회 3,700
18년 전 조회 2,363
18년 전 조회 2,308
18년 전 조회 5,727
18년 전 조회 2,884
18년 전 조회 2,653