자바스크립트에서 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;
}
}
}
덧붙여서 대소문자 구분하지 않고 정렬합니다.
그래서 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에서 이동 됨]
게시글 목록
| 번호 | 제목 |
|---|---|
| 28080 | |
| 7612 | |
| 7598 | |
| 7595 | |
| 19842 | |
| 28079 | |
| 19840 | |
| 7593 | |
| 28076 | |
| 7590 | |
| 28072 | |
| 28065 | |
| 19836 |
jQuery
슬라이드 스크립트 도움 부탁드립니다.
3
|
| 7586 | |
| 28058 | |
| 7573 | |
| 31754 |
부트스트랩
data-toggle 체크박스 활용
|
| 7552 | |
| 28057 | |
| 30993 |
반응형
각 해상도별 테스트.
8
|
| 28052 | |
| 7546 | |
| 7544 | |
| 7538 | |
| 7519 | |
| 30992 |
HTML
결제모듈과 구글웹사이트 번역 엘리먼트
|
| 19834 |
웹서버
리눅스 시스템 백업 복구툴
1
|
| 7517 | |
| 7512 | |
| 7511 | |
| 19832 | |
| 19820 | |
| 7509 | |
| 24658 | |
| 7508 | |
| 7507 | |
| 19818 | |
| 30990 |
HTML
팁] 모바일에서 문자보내기
1
|
| 7506 | |
| 7505 | |
| 7498 | |
| 7492 | |
| 28051 | |
| 7481 | |
| 30988 |
반응형
짧고 굵은거
1
|
| 19813 | |
| 19812 | |
| 7477 | |
| 7476 | |
| 7471 | |
| 7467 | |
| 19810 | |
| 7464 | |
| 19809 | |
| 7463 | |
| 7457 | |
| 30980 | |
| 7450 | |
| 28043 | |
| 7447 | |
| 7440 | |
| 28040 | |
| 7438 | |
| 7430 | |
| 7427 | |
| 7423 | |
| 7414 | |
| 7408 | |
| 7405 | |
| 7401 | |
| 7400 | |
| 19808 | |
| 7398 | |
| 7393 | |
| 7389 | |
| 19805 |
JavaScript
Ajax 로 받은 Json 값을 View 형식에 맞춰 표현
2
|
| 7382 | |
| 7379 | |
| 7378 | |
| 7363 | |
| 7361 | |
| 7356 | |
| 19804 | |
| 7355 | |
| 7352 | |
| 19786 | |
| 7342 | |
| 7336 | |
| 7332 | |
| 19783 | |
| 7328 | |
| 7325 | |
| 7324 | |
| 28036 | |
| 19782 | |
| 7321 | |
| 26574 | |
| 7314 | |
| 7312 | |
| 19781 |
MySQL
MYSQL 쿼리순서, 부하여부 질문드려요
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기