> 웹 프론트엔드 > JS 튜토리얼 > function_javascript 기술을 캡슐화할 때 JavaScript 클로저에 대한 간단한 분석

function_javascript 기술을 캡슐화할 때 JavaScript 클로저에 대한 간단한 분석

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-05-16 18:41:04
원래의
1027명이 탐색했습니다.

wbkt2t는 최근 폐쇄라는 새로운 용어를 발견했습니다. (뒤쳐지니까 열심히 공부해야겠어요.) 바이두와 구글에서 원리와 사례를 보고나서 클로저의 힘도 이해하게 됐어요. JQuery도 클로저를 장려했으며 인터넷에서 개인적으로 개발한 일부 프레임워크에서는 클로저를 사용했습니다. 클로저의 원리와 사용법을 알게 된 후 나는 의심을 품고 조금 시도해 보았습니다. 클로저를 사용하면 어떤 이점이 있습니까? 그것을 사용하지 않으면 어떤 결과가 발생합니까? 다음 코드를 작성했는데 답변을 주실 수 있기를 바랍니다.
클로저 사용:
예제 1

코드 복사 코드는 다음과 같습니다:

var $Darren;
(function(){
var Obj={version:"1.0",author:"Darren"};
Obj.Add=function(arg1,arg2){
return(arg1 arg2);
}
Obj.Multi=function(arg1,arg2){
return(arg1*arg2);
}
$Darren=Obj;
})(); //익명 함수로 즉시 실행
alert($Darren.Add(6,2)) //결과 8
alert ($Darren.Multi(3,5)); //결과 15

클로저 코드를 사용하지 않습니다:
예 2
코드 복사 코드는 다음과 같습니다.

var $Darren2={version:"1.0",author:"Darren"}; >$Darren2.Add= function(arg1,arg2){
return(arg1 arg2);
}
$Darren2.Multi=function(arg1,arg2){
return(arg1*arg2) ;
}
alert($Darren2.Add(6,2)); //결과 8
alert($Darren2.Multi(3,5)) //결과 15

내 이해는 다음과 같습니다.
클로저를 사용하면 이름 지정 충돌을 방지할 수 있습니다. 예를 들어 예제 1에서는 $Darren 변수가 충돌하는 경우 두 곳만 변경하면 되며, 예제 2에서는 $ Darren2 변수 충돌, 여러 변경이 필요합니다.(3곳)
클로저를 사용한 후에는 익명 함수가 실행되더라도 내부 함수를 계속 사용할 수 있습니다.

저도 질문이 있습니다.
왜 다들 예시 1의 글쓰기 방법을 추천하시나요? 예시 1과 예시 2 중 어느 것이 더 좋고, 그 이유는 무엇인가요? 동일한 기능을 얻을 수 있습니다.

모두가 나에게 조언을 해주기를 바랍니다. 이것이 올바른 이해입니까?
더 추가할 사항이 있나요?
모두들 감사합니다~~~
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿