자바스크립트로 오버로딩 구현하기
자바스크립트는 일단 오버로딩 함수를 지원하지 않는다. 다만 매개 변수를 검사하는 방법으로 오버로딩이 되는 것처럼 응용할 수 있다.
function view(){
alert(val);
}
function view(v){
alert(v);
}
함수 선언을 이런 방법으로 했다면 첫번째 view()는 무시되고 view(v)로 인식하게 된다. 브라우저 버전에 따라 동일한 함수명을 사용 할 때 오류가 발생할 수도 있다.
매개변수 개수에 따라 함수 기능을 다르게 하는 방법은 아래 예문과 같다.
function view(){
var a = arguments;
switch (a.length){
case 1: //-- 매개변수가 하나일 때
var val = a[0];
alert(val);
break;
case 2: //-- 매개변수가 두 개 일 때
var val = a[0];
var val2 = a[1];
alert(val + val2);
break;
}
}
view("변수1");
view("변수1", "변수2");
----------------------------------------------------------
switch문을 이용해 매개변수의 개수에 따라 처리 내용을 달리 할 수 있다.
내용이 경어체라 죄송합니다. 반말 했다고 *태*처럼 저한테 욕하지 말아 주세요. ㅡㅡ; 2013년에 제 블로그에 올렸던 거 퍼왔습니다. 잘난척 한다고 할까봐 웬만해서는 Tip 안 올리는데 이건 제가 정말 유용하게 사용하고 있는 거라 공유합니다. ^^
댓글 1개
이렇게도 할수 있습니다.
function view(val){
alert(val);
}
view = (function() {
var cached_function = view;
return function() {
// your code
var a = arguments;
switch (a.length){
case 1: //-- 매개변수가 하나일 때
cached_function.apply(this, a); // use .apply() to call it
break;
case 2 : //-- 매개변수가 두 개 일 때
var val = a[0];
var val2 = a[1];
alert(val + val2);
break;
}
};
}());
view("변수1");
view("변수1", "변수2");
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 7830 | 9년 전 | 427 | ||
| 7829 |
|
9년 전 | 620 | |
| 7828 | 9년 전 | 546 | ||
| 7827 | 9년 전 | 438 | ||
| 7826 | 9년 전 | 441 | ||
| 7825 | 10년 전 | 482 | ||
| 7824 | 10년 전 | 450 | ||
| 7823 | 10년 전 | 387 | ||
| 7822 | 10년 전 | 366 | ||
| 7821 | 10년 전 | 314 | ||
| 7820 | 10년 전 | 351 | ||
| 7819 |
|
10년 전 | 752 | |
| 7818 | 10년 전 | 396 | ||
| 7817 | 10년 전 | 524 | ||
| 7816 | 10년 전 | 413 | ||
| 7815 | 10년 전 | 611 | ||
| 7814 | 10년 전 | 441 | ||
| 7813 | 10년 전 | 380 | ||
| 7812 | 10년 전 | 405 | ||
| 7811 | 10년 전 | 395 | ||
| 7810 | 10년 전 | 571 | ||
| 7809 | 10년 전 | 505 | ||
| 7808 | 10년 전 | 380 | ||
| 7807 | 10년 전 | 409 | ||
| 7806 |
프로그래머7
|
10년 전 | 1337 | |
| 7805 | 10년 전 | 1281 | ||
| 7804 |
zahir1312
|
10년 전 | 782 | |
| 7803 |
|
10년 전 | 1378 | |
| 7802 | 10년 전 | 465 | ||
| 7801 | 10년 전 | 866 | ||
| 7800 | 10년 전 | 1087 | ||
| 7799 | 10년 전 | 561 | ||
| 7798 | 10년 전 | 519 | ||
| 7797 | 10년 전 | 519 | ||
| 7796 | 10년 전 | 359 | ||
| 7795 | 10년 전 | 509 | ||
| 7794 | 10년 전 | 563 | ||
| 7793 | 10년 전 | 1061 | ||
| 7792 | 10년 전 | 480 | ||
| 7791 | 10년 전 | 560 | ||
| 7790 | 10년 전 | 512 | ||
| 7789 |
fbastore
|
10년 전 | 1452 | |
| 7788 | 10년 전 | 551 | ||
| 7787 | 10년 전 | 405 | ||
| 7786 | 10년 전 | 601 | ||
| 7785 | 10년 전 | 590 | ||
| 7784 | 10년 전 | 650 | ||
| 7783 | 10년 전 | 455 | ||
| 7782 | 10년 전 | 496 | ||
| 7781 | 10년 전 | 904 | ||
| 7780 | 10년 전 | 823 | ||
| 7779 | 10년 전 | 777 | ||
| 7778 | 10년 전 | 365 | ||
| 7777 | 10년 전 | 465 | ||
| 7776 | 10년 전 | 463 | ||
| 7775 | 10년 전 | 413 | ||
| 7774 | 10년 전 | 636 | ||
| 7773 | 10년 전 | 387 | ||
| 7772 | 10년 전 | 740 | ||
| 7771 | 10년 전 | 395 | ||
| 7770 | 10년 전 | 650 | ||
| 7769 | 10년 전 | 394 | ||
| 7768 | 10년 전 | 615 | ||
| 7767 | 10년 전 | 1177 | ||
| 7766 | 10년 전 | 495 | ||
| 7765 | 10년 전 | 535 | ||
| 7764 |
잘살아보자
|
10년 전 | 396 | |
| 7763 |
|
10년 전 | 1465 | |
| 7762 |
Tosea
|
10년 전 | 1062 | |
| 7761 | 10년 전 | 652 | ||
| 7760 |
잘살아보자
|
10년 전 | 689 | |
| 7759 |
잘살아보자
|
10년 전 | 517 | |
| 7758 |
잘살아보자
|
10년 전 | 599 | |
| 7757 | 10년 전 | 1248 | ||
| 7756 |
ITBANK
|
10년 전 | 1259 | |
| 7755 | 10년 전 | 1931 | ||
| 7754 | 10년 전 | 1059 | ||
| 7753 | 10년 전 | 888 | ||
| 7752 | 10년 전 | 1400 | ||
| 7751 |
잘살아보자
|
10년 전 | 541 | |
| 7750 |
잘살아보자
|
10년 전 | 483 | |
| 7749 |
잘살아보자
|
10년 전 | 496 | |
| 7748 |
잘살아보자
|
10년 전 | 503 | |
| 7747 |
잘살아보자
|
10년 전 | 596 | |
| 7746 |
잘살아보자
|
10년 전 | 684 | |
| 7745 |
잘살아보자
|
10년 전 | 920 | |
| 7744 |
잘살아보자
|
10년 전 | 420 | |
| 7743 | 10년 전 | 951 | ||
| 7742 |
starbros
|
10년 전 | 845 | |
| 7741 |
잘살아보자
|
10년 전 | 679 | |
| 7740 |
잘살아보자
|
10년 전 | 552 | |
| 7739 |
잘살아보자
|
10년 전 | 468 | |
| 7738 |
잘살아보자
|
10년 전 | 540 | |
| 7737 |
잘살아보자
|
10년 전 | 508 | |
| 7736 |
잘살아보자
|
10년 전 | 529 | |
| 7735 |
잘살아보자
|
10년 전 | 854 | |
| 7734 |
잘살아보자
|
10년 전 | 434 | |
| 7733 |
잘살아보자
|
10년 전 | 547 | |
| 7732 |
잘살아보자
|
10년 전 | 704 | |
| 7731 |
잘살아보자
|
10년 전 | 627 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기