> 백엔드 개발 > PHP 튜토리얼 > 이 두 가지 사용자 정의 이벤트 바인딩 방법의 차이점은 무엇입니까? 어느 것이 더 낫습니까?

이 두 가지 사용자 정의 이벤트 바인딩 방법의 차이점은 무엇입니까? 어느 것이 더 낫습니까?

WBOY
풀어 주다: 2016-09-15 11:15:07
원래의
1746명이 탐색했습니다.

첫 번째 방법은 __onfireEvents에 직접 맞춤 이벤트를 저장하는 것입니다

<code>var __onfireEvents = {};

function _bind(eventName, callback, is_one, context) {
    if (typeof eventName !== string_str || typeof callback !== function_str) {
        throw new Error('args: '+string_str+', '+function_str+'');
    }
    if (! hasOwnKey(__onfireEvents, eventName)) {
        __onfireEvents[eventName] = {};
    }
    __onfireEvents[eventName][++__cnt] = [callback, is_one, context];

    return [eventName, __cnt];
}

function on(eventName, callback, context) {
    return _bind(eventName, callback, 0, context);
}
</code>
로그인 후 복사

두 번째 방법은 커스텀 이벤트를 저장하는 방법인데, 요소에 바인딩된다는 점이 다릅니다. 여기에 장점이 있나요?

<code>$customSubMap = {};
subscribeEvent = function ( $collection, event_name, fn ) {
    $collection.on( event_name, fn );
   

    if ( ! $customSubMap[ event_name ] ) {
        $customSubMap[ event_name ] = $collection;
    }
    else {
        $customSubMap[ event_name ]
        = $customSubMap[ event_name ].add( $collection );
    }
};</code>
로그인 후 복사
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿