찾다

 >  Q&A  >  본문

JQuery的$和其它JS发生冲突的解决方法是怎么样的?

JQuery的$和其它JS发生冲突的解决方法是怎么样的?

末日的春天末日的春天2830일 전1035

모든 응답(2)나는 대답할 것이다

  • 数据分析师

    数据分析师2017-10-01 00:41:03

    JQuery의 $와 다른 JS 간의 충돌에 대한 해결책은 무엇입니까? -PHP 중국어 사이트 Q&A-JQuery의 $와 다른 JS의 충돌에 대한 해결책은 무엇입니까? -PHP 중국어 홈페이지 Q&A

    꼭 보고 배워보세요.

    회신하다
    0
  • 伊谢尔伦

    伊谢尔伦2017-03-04 14:31:06

    众所周知,jQuery是目前最流行的JS封装包,简化了很多复杂的JS程序,JQuery讲浏览器DOM树定义为$,通过$来获取各个子节点。

    然后,JS插件并非只有JQuery,还有prototype.js 等其它比较好的插件。它们也使用$。所以有时候同时使用这个两个JS插件的时候,就会出现$的使用权冲突问题。现在我们来看看如何解决这个冲突问题。请看下文:

    我们都知道JQuery有一个函数,jquery.noConflict() 它的作用是讲$的控制权转让出去。然后我们可以通过jQuery代替$来获取dom节点

    方法一:

    <script type="text/javascript">
    jQuery.noConflict(); //将变量$的控制权让渡给prototype.js
    jQuery(function(){ //使用jQuery
    jQuery("p").click(function(){
    alert( jQuery(this).text() );
    });
    });
    $("pp").style.display = 'none'; //使用prototype
    </script>

    方法二:

    我们可以通过noConflict()函数来定义一个快捷方式用来获取dom节点

    <script type="text/javascript">
    var $j = jQuery.noConflict(); //自定义一个比较短快捷方式
    $j(function(){ //使用jQuery
    $j("p").click(function(){
    alert( $j(this).text() );
    });
    });
    $("pp").style.display = 'none'; //使用prototype
    </script>

    方法三:

    <script type="text/javascript">
    jQuery.noConflict(); //将变量$的控制权让渡给prototype.js
    jQuery(function($){ //使用jQuery
    $("p").click(function(){ //继续使用 $ 方法
    alert( $(this).text() );
    });
    }); 
    $("pp").style.display = 'none'; //使用prototype
    </script>

    方法四:

    <script type="text/javascript">
    jQuery.noConflict(); //将变量$的控制权让渡给prototype.js
    (function($){ //定义匿名函数并设置形参为$
    $(function(){ //匿名函数内部的$均为jQuery
    $("p").click(function(){ //继续使用 $ 方法
    alert($(this).text());
    });
    });
    })(jQuery); //执行匿名函数且传递实参jQuery
    $("pp").style.display = 'none'; //使用prototype
    </script>


    회신하다
    0
  • 취소회신하다