자 바스 크 립 트 타이머 가 전달 파 라미 터 를 호출 하 는 방법

window.setTimeout 이 든 window.setInterval 이 든 함수 명 을 호출 핸들 로 사용 할 때 매개 변 수 를 가 져 갈 수 없 으 며,많은 경우 에 매개 변 수 를 가 져 가 야 합 니 다.이 는 해결 방법 을 생각해 야 합 니 다.예 를 들 어 함수 hello(name),사용자 이름 에 환영 정 보 를 표시 하 는 데 사 용 됩 니 다
 
var userName="Tony";
//
function hello(_name){
alert("hello,"+_name);
}
이 때 다음 문 구 를 사용 하여 hello 함수 의 3 초 실행 을 지연 시 키 려 면 실행 할 수 없습니다.window.setTimeout(hello(userName),3000).이것 은 hello 함 수 를 즉시 실행 시 키 고 반환 값 을 호출 핸들 로 setTimeout 함수 에 전달 합 니 다.그 결 과 는 프로그램 이 필요 로 하 는 것 이 아 닙 니 다.문자열 형식 을 사용 하면 원 하 는 결 과 를 얻 을 수 있 습 니 다:window.setTimeout("hello(userName)",3000).이 문자열 은 자바 스 크 립 트 코드 입 니 다.userName 은 변 수 를 표시 합 니 다.그러나 이러한 쓰기 방법 은 직관 적 이지 않 고 함수 명 을 사용 해 야 하 는 경우 도 있 습 니 다.다음은 작은 기술 로 매개 변수 함수 호출 을 실현 합 니 다
 
<script language="JavaScript" type="text/javascript">
<!--
var userName="jack";
//
function hello(_name){
alert("hello,"+_name);
}
// ,
function _hello(_name){
return function(){
hello(_name);
}
}
window.setTimeout(_hello(userName),3000);
// window.setTimeout( function(){return hello(userName)}, 3000);
// function _hello()
//-->
</script>
함수 를 정의 합 니 다.hello,매개 변 수 를 받 고 매개 변수 가 없 는 함 수 를 되 돌려 줍 니 다.이 함수 내부 에 외부 함수 의 인 자 를 사용 하여 호출 합 니 다.인 자 를 사용 할 필요 가 없습니다.window.setTimeout 함수 에서 을 사용 합 니 다.hello(userName)는 매개 변수 가 없 는 함수 핸들 을 되 돌려 매개 변수 전달 기능 을 실현 합 니 다.

좋은 웹페이지 즐겨찾기