学习笔记:调用js文件冲突问题解决方案

之前自己动手做了一个小网站,在实现过程中遇到了一个关于js文件调用冲突的问题。

具体问题描述如下:在index.html文件中引用了两个js文件,单独添加banner.js或者focus_pic.js都可以运行并且实现相应的功能,但是两个同时添加两个文件后,后banner.js失效了。经过一番研究翻阅了一些资料,并在网上求助于各路大神,终于将问题的原因搞明白了。

banner.js代码如下所示:

 1 var t = n = 0, count; 
 2 $(document).ready(function(){ 
 3 count=$("#banner_list a").length; 
 4 $("#banner_list a:not(:first-child)").hide(); 
 5 $("#banner_info").html($("#banner_list a:first-child").find("img").attr(‘alt‘)); 
 6 $("#banner_info").click(function(){window.open($("#banner_list a:first-child").attr(‘href‘), "_blank")}); 
 7 $("#banner li").click(function() { 
 8 var i = $(this).text() - 1;//获取Li元素内的值,即1,2,3,4 
 9 n = i; 
10 if (i >= count) return; 
11 $("#banner_info").html($("#banner_list a").eq(i).find("img").attr(‘alt‘)); 
12 $("#banner_info").unbind().click(function(){window.open($("#banner_list a").eq(i).attr(‘href‘), "_blank")}) 
13 $("#banner_list a").filter(":visible").fadeOut(500).parent().children().eq(i).fadeIn(1000); 
14 $(this).css({"background":"#be2424",‘color‘:‘#000‘}).siblings().css({"background":"#6f4f67",‘color‘:‘#fff‘}); 
15 }); 
16 t = setInterval("showAuto()", 4000); 
17 $("#banner").hover(function(){clearInterval(t)}, function(){t = setInterval("showAuto()", 4000);}); 
18 }) 
19  
20 function showAuto() 
21 { 
22 n = n >=(count - 1) ? 0 : ++n; 
23 $("#banner li").eq(n).trigger(‘click‘); 
24 } 

focus_pic.js代码如下所示:

  1 var foucsbox = function (time) {
  2     var time = time || 3500
  3     , bigimgs = big.getElementsByTagName(‘li‘)
  4     , samllimgs = samll.getElementsByTagName(‘li‘)
  5     , imglink = tip.getElementsByTagName(‘a‘)[0]
  6     , slide = function (z) {
  7         samllimgs[lastIndex].className = ‘‘;
  8         samllimgs[z].className = ‘current‘;
  9         bigimgs[lastIndex].style.display = ‘none‘;
 10         bigimgs[z].style.display = ‘block‘;
 11         try {
 12             imglink.innerHTML = samllimgs[z].getElementsByTagName(‘img‘)[0].alt;
 13         }
 14         catch (e) {
 15             imglink.innerText = samllimgs[z].firstChild.firstChild.alt;
 16         }
 17         lastIndex = i = z;
 18     }
 19     , helper = function (z) {
 20         return function (e) {
 21             var na;
 22             if (!e) {
 23                 e = window.event;
 24                 na = e.srcElement.nodeName;
 25             }
 26             else {
 27                 na = e.target.nodeName;
 28             }
 29             if (na === ‘IMG‘) {
 30                 slide(z);
 31             }
 32         }
 33     }
 34     , lastIndex = i = 0, x, y = bigimgs.length
 35     , getPrevI = function (q) { return i - q < 0 ? y - q : i - 1; }
 36     , getNextI = function (q) { return i + q >= y ? i + q - y : i + 1; }
 37     try {
 38         imglink.innerText = samllimgs[0].getElementsByTagName(‘img‘)[0].alt;
 39     }
 40     catch (e) {
 41         imglink.innerText = samllimgs[0].firstChild.firstChild.alt;
 42     }
 43     for (x = 1; x < y; x += 1) {
 44         bigimgs[x].style.display = ‘none‘;
 45     }
 46     for (x = 0; x < y; x += 1) {
 47         samllimgs[x].onmouseover = helper(x);
 48     }
 49     topCon.children[2].onclick = function (e) {
 50         i = lastIndex;
 51         var t;
 52         if (!e) {
 53             e = window.event;
 54             t = e.srcElement;
 55         } else {
 56             t = e.target;
 57         }
 58         switch (t.className) {
 59             case ‘icon_prev‘:
 60                 slide(getPrevI(1));
 61                 break;
 62             case ‘icon_next‘:
 63                 slide(getNextI(1));
 64                 break;
 65         }
 66     };
 67     topCon.onmouseover = function () {
 68         clearInterval(s);
 69     };
 70     topCon.onmouseout = function () {
 71         s = setInterval(function () {
 72             slide(i);
 73             i = getNextI(1);
 74         }, time);
 75     };
 76 };
 77  
 78      var $ = function (id) { return document.getElementById(id); }
 79     , topCon = $(‘flower1‘)
 80     , big = $(‘focus_pic1‘)
 81     , samll = $(‘focus_list1‘)
 82     , tip = $(‘focus_title1‘)
 83         foucsbox(2500);
 84     
 85      var topCon = $(‘flower2‘)
 86     , big = $(‘focus_pic2‘)
 87     , samll = $(‘focus_list2‘)
 88     , tip = $(‘focus_title2‘)
 89         foucsbox(2500);
 90      
 91      var topCon = $(‘flower3‘)
 92     , big = $(‘focus_pic3‘)
 93     , samll = $(‘focus_list3‘)
 94     , tip = $(‘focus_title3‘)
 95         foucsbox(2500);
 96     
 97      var topCon = $(‘flower4‘)
 98     , big = $(‘focus_pic4‘)
 99     , samll = $(‘focus_list4‘)
100     , tip = $(‘focus_title4‘)
101         foucsbox(2500);

问题的原因在于var $ = function (id) { return document.getElementById(id); }
就是这段覆盖了jquery的工厂函数,解决办法有2个,
解决方法1:把这个块换个名字

  1 var foucsbox = function (time) {
  2     var time = time || 3500
  3             , bigimgs = big.getElementsByTagName(‘li‘)
  4             , samllimgs = samll.getElementsByTagName(‘li‘)
  5             , imglink = tip.getElementsByTagName(‘a‘)[0]
  6             , slide = function (z) {
  7                 samllimgs[lastIndex].className = ‘‘;
  8                 samllimgs[z].className = ‘current‘;
  9                 bigimgs[lastIndex].style.display = ‘none‘;
 10                 bigimgs[z].style.display = ‘block‘;
 11                 try {
 12                     imglink.innerHTML = samllimgs[z].getElementsByTagName(‘img‘)[0].alt;
 13                 }
 14                 catch (e) {
 15                     imglink.innerText = samllimgs[z].firstChild.firstChild.alt;
 16                 }
 17                 lastIndex = i = z;
 18             }
 19             , helper = function (z) {
 20                 return function (e) {
 21                     var na;
 22                     if (!e) {
 23                         e = window.event;
 24                         na = e.srcElement.nodeName;
 25                     }
 26                     else {
 27                         na = e.target.nodeName;
 28                     }
 29                     if (na === ‘IMG‘) {
 30                         slide(z);
 31                     }
 32                 }
 33             }
 34             , lastIndex = i = 0, x, y = bigimgs.length
 35             , getPrevI = function (q) { return i - q < 0 ? y - q : i - 1; }
 36             , getNextI = function (q) { return i + q >= y ? i + q - y : i + 1; }
 37     try {
 38         imglink.innerText = samllimgs[0].getElementsByTagName(‘img‘)[0].alt;
 39     }
 40     catch (e) {
 41         imglink.innerText = samllimgs[0].firstChild.firstChild.alt;
 42     }
 43     for (x = 1; x < y; x += 1) {
 44         bigimgs[x].style.display = ‘none‘;
 45     }
 46     for (x = 0; x < y; x += 1) {
 47         samllimgs[x].onmouseover = helper(x);
 48     }
 49     topCon.children[2].onclick = function (e) {
 50         i = lastIndex;
 51         var t;
 52         if (!e) {
 53             e = window.event;
 54             t = e.srcElement;
 55         } else {
 56             t = e.target;
 57         }
 58         switch (t.className) {
 59             case ‘icon_prev‘:
 60                 slide(getPrevI(1));
 61                 break;
 62             case ‘icon_next‘:
 63                 slide(getNextI(1));
 64                 break;
 65         }
 66     };
 67     topCon.onmouseover = function () {
 68         clearInterval(s);
 69     };
 70     topCon.onmouseout = function () {
 71         s = setInterval(function () {
 72             slide(i);
 73             i = getNextI(1);
 74         }, time);
 75     };
 76 };
 77  
 78 var byId = function (id) { return document.getElementById(id); }
 79         , topCon = byId(‘flower1‘)
 80         , big = byId(‘focus_pic1‘)
 81         , samll = byId(‘focus_list1‘)
 82         , tip = byId(‘focus_title1‘)
 83 foucsbox(2500);
 84  
 85 var topCon = byId(‘flower2‘)
 86         , big = byId(‘focus_pic2‘)
 87         , samll = byId(‘focus_list2‘)
 88         , tip = byId(‘focus_title2‘)
 89 foucsbox(2500);
 90  
 91 var topCon = byId(‘flower3‘)
 92         , big = byId(‘focus_pic3‘)
 93         , samll = byId(‘focus_list3‘)
 94         , tip = byId(‘focus_title3‘)
 95 foucsbox(2500);
 96  
 97 var topCon = byId(‘flower4‘)
 98         , big = byId(‘focus_pic4‘)
 99         , samll = byId(‘focus_list4‘)
100         , tip = byId(‘focus_title4‘)
101 foucsbox(2500);

解决方法2:由于js的变量作用域或作用范围是按函数来划分界限的,所以放在一个函数里边,把他执行一下。一般通俗的叫:立即执行函数。这样,这个内部$不会穿透,或影响到外边去。这是一种偷懒或省力的解决办法。但是这个方法的缺点是:要求的技术储备比较高,里边也有少量的坑。比如,即不让$穿透,还需要把里边的方法暴露给外边。这时候需要借助window,把方法绑定在window上面去。比如:window.method = method.

 1 (function(window){
 2     var $ = function(id) {
 3             return document.getElementById(id);
 4         },
 5         topCon = $(‘flower1‘),
 6         big = $(‘focus_pic1‘),
 7         samll = $(‘focus_list1‘),
 8         tip = $(‘focus_title1‘);
 9     foucsbox(2500);
10  
11     var topCon = $(‘flower2‘),
12         big = $(‘focus_pic2‘),
13         samll = $(‘focus_list2‘),
14         tip = $(‘focus_title2‘);
15     foucsbox(2500);
16  
17     var topCon = $(‘flower3‘),
18         big = $(‘focus_pic3‘),
19         samll = $(‘focus_list3‘),
20         tip = $(‘focus_title3‘);
21     foucsbox(2500);
22  
23     var topCon = $(‘flower4‘),
24         big = $(‘focus_pic4‘),
25         samll = $(‘focus_list4‘),
26         tip = $(‘focus_title4‘);
27     foucsbox(2500);
28 }(window))

以上方法就可以成功解决问题啦!感谢大神的指点,受益匪浅!前端的路,才刚刚开始,希望以后可以更多的发现问题,解决问题,分享经验!

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。