오늘 "JavaScript 소개 - 이벤트" 장에서 이것과 이벤트의 두 가지 매개변수 전달 형식을 보았습니다. 저는 주니어 프론트엔드 개발자로서 주로 매개변수를 전달하는 데에만 이것을 사용하기 때문에 이것과 이벤트의 차이점이 무엇인지, 어떤 상황에서 사용하는 것이 더 적합한지 알고 싶습니다.
onclick =changeImg(this) vs onclick =changeImg(event)
<img src='usa.gif' onclick="changeImg(event)" /> <script> var myImages = [ 'usa.gif','canada.gif','jamaica.gif','mexico.gif' ]; function changeImg(e) { var el = e.target; var newImgNumber = Math.round(Math.round()*3); while(el.src.indexOf(myImages[newImgNumber]) != -1){ el.src =myImages[newImgNumber]; } } </script>
1.this는 Javascript 언어의 키워드입니다.
2.함수 실행 시 자동으로 생성되는 내부 객체를 나타내며 함수 내부에서만 사용할 수 있습니다.
3. 이것과 event.target의 차이점:
js의 이벤트는 버블링되므로 변경될 수 있지만 event.target은 변경되지 않습니다(이벤트가 트리거되면 현재 이벤트 개체의 참조만 변경됩니다). ), 이벤트를 직접 받아들이는 것은 항상 대상 DOM 요소입니다.
또한 this와 event.target은 모두 jquey에서 메서드를 사용하려는 경우 jquery 개체로 변환할 수 있습니다. this) 및 $(event .target);
위 내용은 JS 이벤트와 이 이벤트의 차이점에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!