Develop
2013.04.23 15:10
[js] 셀렉트박스(select)의 옵션(option) 동적으로 추가/제거
조회 수 8082 댓글 0
첨부 '1' |
---|
좋은 예제인듯..
아래는 주요 함수 부분임~
<script> /* *Source Select의 요소(option)를 Target Select로 복사한다. */ function copyElement(sourceObj, targetObj){ var elms = sourceObj.options; for( i = 0, k = elms.length; i < k; i++ ){ if( elms[i].selected ){ targetObj.add(new Option(elms[i].text, elms[i].value, false, false)); } } sourceObj.selectedIndex=-1; } /* *Source Select의 요소(option)를 제거한다. */ function removeElement(sourceObj){ var elms = sourceObj.options; var posArr = new Array(); var increase = 0; for( i = 0, k = elms.length; i < k; i++ ){ if( elms[i].selected ){ posArr[increase++] = elms[i].value; } } for( i = 0, k = posArr.length; i < k; i++ ){ for( x = 0, y = elms.length; x < y; x++ ){ if( (posArr[i] == elms[x].value) && elms[x].selected ){ sourceObj.remove(x); x = 0; y--; } } } } /* *Source Select의 요소(option)를 Target Select로 이동한다. */ function moveElement(sourceObj, targetObj, isSort){ var elms = sourceObj.options; for( i = 0, k = elms.length; i < k; i++ ){ if( elms[i].selected ){ targetObj.add(new Option(elms[i].text, elms[i].value, false, false)); } } removeElement(sourceObj); sourceObj.selectedIndex = -1; } /* *Source Select의 요소(option)의 상하순서를 바꾼다. */ function move_option_in(src,to) { if(!src)return; var src_index = src.selectedIndex; if(src_index<0)return; if(to == "up"){ if(src_index==-1||src_index==0)return; var tempoption = new Option(src.options[src_index].text, src.options[src_index].value); src.options[src_index] = new Option(src.options[src_index-1].text, src.options[src_index-1].value); src.options[src_index-1]=tempoption; src.options[src_index-1].selected=true; }else if(to == "down"){ if(src_index>=src.options.length-1)return; var tempoption = new Option(src.options[src_index].text, src.options[src_index].value); src.options[src_index] = new Option(src.options[src_index+1].text, src.options[src_index+1].value); src.options[src_index+1]=tempoption; src.options[src_index+1].selected=true; } } </script>
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
505 | Develop | [c] 단기과정[01/17] 후위연산 스택 계산기.. | hooni | 2003.04.23 | 7255 |
504 | Develop | [c] 단기과정[01/15] 피보나치, 파스칼.. 링크리스트 | hooni | 2003.04.23 | 7259 |
503 | Develop | [php] 웹 터미널 & 업로드 소스.. | hooni | 2013.04.23 | 7261 |
502 | Develop | [c] 단기과정[01/08] 배열, 포인터 | hooni | 2003.04.23 | 7267 |
501 | Develop | [c++] mfc로 만든 인테리어 수납 시스템(2D기반 설계) | hooni | 2013.04.23 | 7276 |
500 | Develop | [linux] crond 사용법.. ㅋㅋ | hooni | 2013.04.23 | 7277 |
499 | Develop | [chm] Programming Applications for Microsoft Windows | hooni | 2013.04.23 | 7282 |
498 | Develop | [php] 논문 관리 프로그램.. ㅋㅋ | hooni | 2013.04.23 | 7284 |
497 | Develop | [c] 무선 Radius Server 자료.. | hooni | 2013.04.23 | 7284 |
496 | Develop | [c] 패킷정보출력(경로, 패킷길이, 3hand, sync, ack..) | hooni | 2003.04.23 | 7286 |
495 | Develop | [c++] mfc로 만든 부엌 수납 시스템(2D기반 설계) | hooni | 2013.04.23 | 7289 |
494 | Develop | [c] 신기한 atoi함수(www.game79.net) | hooni | 2003.04.23 | 7291 |