2个jQuery脚本冲突

时间:2014-02-12 12:53:36

标签: jquery css fancybox conflict stoppropagation

我有一个链接到fancybox的按钮和另一个切换隐藏的联系表单的按钮。 他们都独自工作,但我不能让他们在一起时工作。我认为 它可能与我的脚本中的stopPropagation有关?有谁知道我能做些什么来阻止他们发生冲突?

<div class="buttoncont">
        <div class="innercont">
        <div class="thanks" style="display:none;"><p>Thanks for contacting class</p></div>
            <div class="social">
                <!— FANCYBOX BUTTON LINK —>
                <div class="fancybox-media" href="http://vimeo.com/9532951" rel="media-gallery">
                <a class="btn"> <span class="playarrow"></span><span>watch fancybox preview</span></a></div>
                    <!— FANCYBOX BUTTON LINK END—>
                <!— CONTACT US LINK —>  
                <a class="btn2" href="#innercont" id='link'><span class="contactbbl"></span><span>contact us</span></a>
                    <!— CONTACT US LINK END —> 
            </div>
<div id="subscribe-pop”><p>DIV POPUP TRIGGERED FROM CONTACT US LINK</p></div>

<div id="badge1”>
    <a href="http://www.site1.com"><img class="badge1" src="images/badge1.png" height="auto" width="100%"></a>
</div>
<div id=“badge2”>
        <a href="http://www.site2.com"><img class="badge2” src="images/badge2.png" height="auto" width="100%"></a>
</div>

</div>
</div>

联系表格SCRIPT

<script type="text/javascript">

$('html').click(function() {
    $('#subscribe-pop').hide();
    $('.thanks').hide(); 
 });

 $(‘.innercont’).click(function(e){
     e.stopPropagation();
 });

$('#link').click(function(e) {
 $('#subscribe-pop').toggle();
 });

$('#mc_embed_signup .button').click(function(e) { 
 $('#subscribe-pop').hide(); 
 $('.thanks').toggle(); 
 });

 $('#mc_embed_signup .cancel').click(function(e) { 
 $('#subscribe-pop').hide(); 

 });

$('.thanks').click(function() { 
 $('.thanks').hide(); 
 });

</script>

FANCY BOX SCRIPT

<script type="text/javascript">
        $(document).ready(function() {
            $('.fancybox-media')
                .attr('rel', 'media-gallery')
                .fancybox({
                    padding: 0,
                    openEffect : 'none',
                    closeEffect : 'none',
                    prevEffect : 'none',
                    nextEffect : 'none',
                    arrows : false,
                    helpers : {
                        media : {},
                        buttons : {}
                    }
                });
                        });
    </script>

1 个答案:

答案 0 :(得分:0)

可能是因为Jquery冲突。

两个javascript库之间总是存在冲突的可能性

尝试

var $j = jQuery.noConflict();

现在,您可以在jquery代码中使用$j代替$

jquery conflict