"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 괄호를 사용할 때 JavaScript onclick 함수가 조기에 트리거되는 이유는 무엇입니까?

괄호를 사용할 때 JavaScript onclick 함수가 조기에 트리거되는 이유는 무엇입니까?

2024년 11월 10일에 게시됨
검색:130

Why Does JavaScript onclick Function Trigger Prematurely When Parentheses Are Used?

JavaScript onclick 함수가 너무 일찍 트리거됨

태그와 유사한 미학적 링크를 생성하지만 클릭 시 함수를 실행하려는 경우 , 사용자는 페이지 로드 시 함수가 잘못 호출되는 시나리오를 접할 수 있습니다. 이는 원하는 클릭 이벤트가 올바르게 작동하는 것을 방해합니다.

일반적인 함정은 onclick 속성을 할당할 때 괄호를 부적절하게 사용하는 것입니다. 함수를 즉시 실행하는 sentNode.onclick = secondFunction() 대신 올바른 구문은 sentNode.onclick = secondFunction입니다. 이는 클릭 이벤트 시에만 실행되는 함수에 대한 참조를 할당합니다.

function startFunction() {
  var sentNode = document.createElement('a');
  sentNode.setAttribute('href', "#");
  sentNode.setAttribute('onclick', secondFunction);
  //sentNode.onclick = secondFunction();
  sentNode.innerHTML = "Sent Items";
  //...
}

괄호를 생략하면 onclick 이벤트가 실행 결과가 아닌 함수 참조에 올바르게 바인딩되어 의도한 동작이 보장됩니다.

릴리스 선언문 이 글은 1729552154에서 재인쇄되었습니다. 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3