曾经,我非常羡慕那些人见人爱的人,我也想要变成那样,可是后来我才明白人见人爱也是需要天赋的,后来我开始默默努力,我想,就算我不能让每个人都喜欢我,至少因为我做的努力能得到别人的尊重。

当页面有多个js文件时,应如何引入?

  1. 我们知道如果一个页面有多个js文件,并且这些js文件有的还有依赖关系的时候,我们就要特别注意他们之间的引入顺序,否则就会报错。

   如:一个js文件依赖jquery,我们就要先引入jquery,然后再引入这个js文件,否则,就会报错$ is not defined。

  

  2. 当一个页面有多个js文件的时候,另一个可能出现的问题就是 window.onload = function() { // doSomething() };这个函数出现了多次,这样,只有最后一次出现的才会执行,而之前被引入的js文件的window.onload 函数会被后面引入的包含的window.onload函数覆盖,这一点需要格外注意。举例如下:

例1:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>window.onload</title>
</head>
<body>
    <div class="test">这是一段文字</div>
    <script>
        var para = document.getElementsByClassName("test")[0];
        window.onload = function() {    
            para.style.color = "red";
        }
        window.onload = function() {
            para.style.fontSize = "50px";
        }
    </script>
</body>
</html>
View Code

  这时,我们得到的是文字很大(50px),颜色还是默认的黑色。

例2:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>window.onload</title>
</head>
<body>
    <div class="test">这是一段文字</div>
    <script>
        var para = document.getElementsByClassName("test")[0];
        window.onload = function() {
            para.style.fontSize = "50px";
        }
        window.onload = function() {    
            para.style.color = "red";
        }
    </script>
</body>
</html>
View Code

  这时,我们的到文字是默认的16px,但是颜色已经改变了。

  结论: 第二个window.onload确实会覆盖第一个出现的window.onload函数。 

  解决方法1: 将所有的语句写在一个window.onload函数中

  解决方法2: 使用《JavaScript DOM编程艺术》一书中所推荐的方法。

 

  

posted @ 2017-03-02 03:06  Wayne-Zhu  阅读(5421)  评论(0编辑  收藏  举报

一分耕耘,一分收获。