• js在html中的加载执行顺序


    1.加载顺序:引入标记<script />的出现顺序,依次加载

    页面上的Javascript代码是HTML文档的一部分,所以Javascript在页面装载时执行的顺序就是其引入标记<script />的出现顺序, 
    <script />标记里面的或者通过src引入的外部JS,都是按照其语句出现的顺序执行,而且执行过程是文档装载的一部分。

    2、每个脚本定义的全局变量函数,都可以被后面执行的脚本所调用。

      变量的调用,必须是前面已经声明,否则获取的变量值是undefined。

    <script type="text/javscrpt">//<![CDATA[  
      alert(tmp);    
      //输出 undefined var   
      tmp = 1;  
      alert(tmp);  //输出 1//]]>  
    </script>  

    3.同一段脚本,函数定义可以出现在函数调用的后面,但是如果是分别在两段代码,且函数调用在第一段代码中,则会报函数未定义错误。

    <script type="text/javscrpt">//<![CDATA[  
      aa();            //浏览器报错//]]>  
    </script>  
    <script type="text/javscrpt">//<![CDATA[  
      aa();   //输出 1   
      function aa()  
      {  
        alert(1);  
      }//]]>  
    </script>  

    4、同名JS函数执行顺序

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">   
    <html>  
    <head>  
    <script  type="text/javascript">  
      
        function aa() {  
            alert('First aa')  
        }     
    </script>     
        <title></title>  
    </head>  
    <body>  
        <form id="form1" runat="server">  
      
    <br />  
    <input id="Button1" type="button" value="button"  onclick="aa();"/>  
        </form>  
    </body>  
    <script  type="text/javascript">  
        function aa(s) {  
            alert('Second aa');  
        }  
        function aa(s) {  被执行
            alert('Last aa');  
        }  
    </script>  
    </html>  

    执行最后面的同名函数 所以结果为 点击“botton”执行结果: Last aa

    5.document.write()会把输出写入到脚本文档所在的位置,浏览器解析完documemt.write()所在文档内容后,继续解析document.write()输出的内容,解析完成后
    再继续解析HTML文档。

    <script type="text/javascript">//<![CDATA[      
      document.write('<script type="text/javascript" src="test.js"></'+'script>');  
      document.write('<script type="text/javascript">');
      document.write('alert("2");') ;     
      document.write('alert("我是" + tmpStr);');      
      document.write('</'+'script>');    
    </script>   
      
    <script type="text/javascript">
      alert(3);  
    </script>
    test.js文件内容
    var tmpStr=2;
    alert(tmpStr);

    执行顺序 2 2 我是  2  3

    6.在js中引入js文件时一定要注意<script></script>的分隔导入,否则会截断主文件的js,主要是后面的</script>结尾标签

    document.write("<scr"+"ipt src='my.js'></scr"+"ipt>"); 

    document.write('<script type="text/javascript" src="test.js"></'+'script>');
  • 相关阅读:
    【翻译】Longest Palindromic Substring 最长回文子串
    java三大框架学习总结(1)
    select XXX into 和 Insert into XXX select
    在WinForm编程中犯的一些错误
    自定义类型数组排序的两种实现方式
    C# 释放非托管资源
    在已创建的DataTable对象中添加在首列一列
    WinForm编程时窗体设计器中ComboBox控件大小的设置
    php处理序列化jQuery serializeArray数据
    谈谈对程序员的培养
  • 原文地址:https://www.cnblogs.com/jiechn/p/4029258.html
Copyright © 2020-2023  润新知