개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.05.08 10:32

추가된 Event Listeners에 대한 질문

목록
  • 웹접근성장인 2일 전 2025.05.08 10:32
  • 4
    1
제가 현재 LWC 개발을 하면서 Event Bus를 사용하여 Event를 전송하고 있습니다. 그런데 add메서드를 사용하여 Event Listeners를 추가할 때에 특정한 옵션을 사용하여 특정 Event에만 등록하고 싶은데요.

add() 메서드의 세 번째 인자로 제공하는 옵션을 어떻게 사용하는 것이 좋을까요?

javascript

this.events = this.events || this.container.getEventBus();

this.events.add('myEvent', this.handler, this);


이러한 경우에 어떤 옵션을 사용하여 특정 Event에만 등록할 수 있을까요?

    댓글목록

    profile_image
    나우호스팅  2일 전



    Event Bus의 add() 메서드의 세 번째 인자로 제공하는 옵션은 옵션 객체입니다. 이 옵션 객체를 사용하여 특정 Event에만 등록할 수 있습니다.

    예를 들어, 특정 Event에만 등록하고 싶을 때, 다음과 같이 옵션 객체를 사용할 수 있습니다.

    #hostingforum.kr
    javascript
    
    this.events.add('myEvent', this.handler, this, {
    
      filter: (event) => event.type === 'myEvent' && event.data === 'specificData'
    
    });
    
    


    이 옵션 객체의 filter 속성을 사용하여 특정 Event에만 등록할 수 있습니다. filter 속성은 함수 형태로 제공되며, Event가 전송될 때마다 이 함수가 호출됩니다. 이 함수는 Event를 필터링하여 특정 Event에만 등록할 수 있습니다.

    또한, add() 메서드의 두 번째 인자로 제공하는 핸들러 함수에 filter 속성을 직접 추가할 수도 있습니다.

    #hostingforum.kr
    javascript
    
    this.handler = {
    
      filter: (event) => event.type === 'myEvent' && event.data === 'specificData',
    
      handle: (event) => {
    
        // Event 핸들링 코드
    
      }
    
    };
    
    
    
    this.events.add('myEvent', this.handler, this);
    
    


    이 방법을 사용하면 핸들러 함수에 filter 속성을 직접 추가할 수 있습니다.

    2025-05-08 10:33

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 18,258건 / 41 페이지

검색

게시물 검색