• 회원가입
  • 로그인
  • 구글아이디로 로그인

[Misc] JQ - noConflict() 메서드 ★★★ - javascript (JS) 기반의 다른 프레임워크와의 충돌방지 (= 제이쿼리기호변경 = 제이쿼리 신버전 구버전 동시 사용)

noConflict() 메서드 의미

 

제이쿼리처럼 $ 단축 식별자 사용하는 JS 기반의 다른 프레임워크와 충돌 (= 한쪽 기능 마비) 방지.
즉,
noConflict () 메소드는 다른 스크립트가 $ 기호를 사용할 수 있도록 $ 단축 식별자를 해제시키고
$ 단축 식별자 대신 제이쿼리 전체 이름인  jQuery 사용할 수 있도록 함. (예제 보는 게 이해 빠름)

 

 

 

 $ 기호 사용하는 타 언어와의 충돌 방지 

 

noConflict() 방법1 - $기호 대신 jQuery 사용

 

<!DOCTYPE html>

<html>

<head>

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<script>

$.noConflict(); // 지금부터는 $기호 대신 jQuery 사용할거야.

jQuery(document).ready(function(){

    jQuery("button").click(function(){

        jQuery("p").text("Homzzang.com");

    });

});

</script>

</head>

<body>


<p>홈짱닷컴 주소?</p>

<button>냉큼 보여 줘.</button>


</body>

</html>



결과 보기

 

 

noConflict() 방법2 - $기호 대체할 단축 식별자 임의 생성

 

<!DOCTYPE html>

<html>

<head>

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<script>

var hz = $.noConflict(); // $기호 대신 hz 사용할거야.

hz(document).ready(function(){

    hz("button").click(function(){

        hz("p").text("Homzzang.com");

    });

});

</script>

</head>

<body>


<p>홈짱닷컴 주소?</p>

<button>닁큼 보여줘!</button>


</body>

 

</html>



결과 보기

 

 

 

noConflict() 방법3 - jQuery와 $기호 동시 사용

 

<!DOCTYPE html>

<html>

<head>

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<script>

$.noConflict();

jQuery(document).ready(function($){

    $("button").click(function(){

        $("p").text("Homzzang.com");

    });

});

</script>

</head>

<body>


<p>홈짱닷컴 주소?</p>

<button>제발 알려줘.</button>


</body>

</html>



결과 보기

함수 바깥의 파란색 굵은 글씨 jQuery 는 반드시 jQuery 이렇게 써야 하지만,

함수 안의 매개변수 핑크색 굵은 글씨 $ 기호는 임의로 정의해 사용 가능 함.

 

PS.

아래처럼 정의 후 사용해도 무방

 

<scrip>var jQuery=jQuery.noConflict();</script>

 

 

 


 제이쿼리 구버전, 신버전 동시 사용 

 

방법1 - 새 버전만 별도 정의


그누5 구버전 JQUERY
<script src="<?php echo G5_JS_URL?>/jquery-1.8.3.min.js"></script>
$("선택자")형식으로 사용

 

그누5 신버전 JQUERY

<script src="http://code.jquery.com/jquery-latest.js"></script>

<script>var jQuery= $.noConflict(true);</script>

jQuery("선택자") 형식으로 사용 

 

 

또는,

 

방법2 - 각각 별도 정의

 

 

<script src="<?php echo G5_JS_URL?>/jquery-1.8.3.min.js"></script>

<script>

  var jqo = jQuery.noConflict();

</script>

jqo("선택자") 형식으로 사용

 

 

<script src="<?php echo G5_JS_URL?>/jquery-1.12.4.min.js"></script>

<script>

  var jqn = jQuery.noConflict();

</script>

jqn("선택자") 형식으로 사용

 

※ 에러 날 수도 있으니, 충분히 테스트 후 사용.


분류 제목
Event JQ - select() 메서드 - 입력창의 문자열 드래그 선택. (= select이벤트 = 실렉트/셀렉트 …
Event JQ - submit() 메서드 ★ - 폼 입력값 전송 이벤트 촉발/실행함수 지정. (= submit메서드 …
Event JQ - toggle() 메서드 - JQ 1.9 폐기완료. / 여러 클릭 이벤트간 상호전환. (= togg…
Event JQ - trigger() 메서드 ★ - 지정 이벤트 수동 촉발과 이벤트 기본동작 수행. (= trigger…
Event JQ - triggerHandler() 메서드 - 지정 이벤트 수동 촉발만 함. (= 트리거핸들러 메서드)
Event JQ - unbind() 메서드 - JQ 3.0 폐기예고, off() 메서드로 대체. 추가된 이벤트핸들러 제…
Event JQ - undelegate() 메서드 - JQ 3.0 폐기예고. off() 메서드로 대체. / 이벤트핸들러…
Event JQ - unload() 메서드 - JQ 3.0 폐기완료. / 페이지 떠날 때 실행. (= 언로드 메서드)
Effect JQ - clearQueue() 메서드 - 선택요소에서 실행 대기 함수 모두 제거/삭제. (= clearQu…
Effect JQ - delay() 메서드 - 실행 대기 함수의 실행을 지연. (= delay메서드 = 딜레이메서드)
Effect JQ - dequeue() 메서드 - 실행 대기 함수를 계속 실행. (= dequeue메서드 = 디큐메서드)
Effect JQ - fadeIn() 메서드 - 선택요소를 천천히 나타나게 하기. (= fadeIn메서드 = 페이드인메서…
Effect JQ - fadeOut() 메서드 - 선택요소를 천천히 사라지게 하기. (= fadeOut메서드 = 페이드아…
Effect JQ - fadeTo() 메서드 - 지정 불투명도로 서서히 변경 (= fadeTo메서드 = 페이드투메서드)
Effect JQ - fadeToggle() 메서드 ★ - fadeIn(), fadeOut() 메서드 상호 전환. (= …
Effect JQ - finish() 메서드 - 모든 실행 함수 중지/제거/완성. (= finish메서드 = 피니시메서드…
Effect JQ - hide() 메서드 - 선택요소 감추기/숨기기/비노출. (= hide메서드 = 하이드메서드)
Effect JQ - queue() 메서드 -실행 대기 함수 개수 표시. (= queue메서드 = 큐메서드)
Effect JQ - show() 메서드 - 선택요소 보이기/보이게하기/노출/나타내기/ = show메서드 = 쇼우메서드)
Effect JQ - slideDown() 메서드 - 선택요소를 밑으로 슬라이드해 보여주기 (= slideDown메서드 …
8/15
목록
찾아주셔서 감사합니다. Since 2012