zoukankan      html  css  js  c++  java
  • <script language = "javascript">, <script type = "text/javascript">和<script language = "application/javascript">(转)

     
     
     
    application/javascript是服务器端处理js文件的mime类型,text/javascript是浏览器处理js的mime类型,后者兼容性更好(虽然application/javascript才是正确写法,由于现在大家都写错的,导致浏览器厂商对写application/javascript兼容性更好)。等以后大家都用HTML5的时候,就不需要写这个了。直接<script></script>就OK了!
     
    另外
    <script language = "javascript">

    <script type = "text/javascript">

    <script>

    这三个标签的使用有什么区别?

    虽然一直在用,却也没有好好去弄清楚,这里详细说明一下。

    查阅一些资料,主要是浏览器支持问题。type 和 language 属性都可用来指定 <script> 标签中的脚本的类型。language 属性在 HTML 和 XHTML 标准中受到了非议,这两个标准提倡使用 type 属性。遗憾的是,这两个属性的值是不一样的。

    您可能偶尔会看见 language 的值为 VBScript(对 type 而言是 text/vbscript),表示包含的脚本代码是用 Microsoft 的 Visual Basic Script 编写的。

    利用 JavaScript,您还可以使用 language 的值 "JavaScript 1.1",表示包含的脚本语句只能被 Netscape 3.0 或更新的版本处理。Netscape 2.0 只支持 JavaScript 1.0,而无法处理标记为 "JavaScript 1.1" 的脚本。

    为了保证脚本程序可以正常执行,除非特意使用仅 IE 支持的 VBScript 和 Script Encoder 机制外,应当将 SCRIPT 标记的 "type" 属性设置为 "javascript",并且不要设置已经废弃的 "Languange" 属性。

    各浏览器对于 "type" 和 "language" 属性本身均支持,但是对于其中设置的脚本语言类型识别与支持各异:

    • "type" 和 "language" 同时存在时,所有浏览器均优先识别 "type" 属性内的脚本类型;

    • 其中 IE 浏览器实际支持 JScript 和 VBScript 脚本语言标示以及 Script Encoder 加密;

    • Firefox Chrome Safari Opera 对 "type" 属性值的具体识别宽容度不一致,相对 Chrome Safari 对属性值正确性校验更加宽松,Firefox 的校验最为严格;

    • 在 "Language" 属性值识别宽容度比较中,各浏览器中 Chrome Safari 依然最为宽松,IE 最为严格,Firefox 与 Opera 持平;

    • Language Encode 比较中,只有 IE 支持 JScript.Encoder 以及 VBScript.Encoder 类型设置,Firefox Chrome Safari均不支持,Opera 中则是该属性值被修复为默认的 Javascript 脚本语言后才有输出值。

    关于变量有一个问题,即使你在函数内如同上面那样声明变量,它就会变成全局变量。

    如果用 var 声明就会有一个问题。

     

    结果依然会弹出a。

    为了保证脚本程序可以正常执行,除非特意使用仅 IE 支持的 VBScript 和 Script Encoder 机制外,应当将 SCRIPT 标记的 "type" 属性设置为 "javascript",并且不要设置已经废弃的 "Languange" 属性。

    示例:

     
     1 <script type="javascript">  
     2 function a(){  
     3     var i="aaa";  
     4     delete i;  
     5     alert(i);  
     6 }  
     7 a();  
     8 </script>  
     9   
    10 <script type="text/javascript">  
    11 function b(){  
    12     var i="bbb";  
    13     delete i;  
    14     alert(i);  
    15 }  
    16 b();  
    17 </script>  
    18   
    19 <script>  
    20 function c(){  
    21     var i="ccc";  
    22     delete i;  
    23     alert(i);  
    24 }  
    25 c();  
    26 </script>  
    27   
    28 <script language="javascript">  
    29 function d(){  
    30     var i="ddd";  
    31     delete i;  
    32     alert(i);  
    33 }  
    34 d();  
    35 </script>  

     

    总结:虽然 测试结果是type="javascript"  但是我们平时都用的是type="text/javascript"  只要小心仔细,不怕出错。

    至于language="javascript" 和 <script> 还是不要再用了

  • 相关阅读:
    微信小程序之授权 wx.authorize
    微信小程序之可滚动视图容器组件 scroll-view
    纯 CSS 利用 label + input 实现选项卡
    Nuxt.js + koa2 入门
    koa2 入门(1)koa-generator 脚手架和 mongoose 使用
    vue 自定义指令
    时运赋
    WEBGL 2D游戏引擎研发系列 第一章 <新的开始>
    EasyUI特殊情况下的BUG整理
    数字时钟DigClock
  • 原文地址:https://www.cnblogs.com/wgbs25673578/p/4963299.html
Copyright © 2011-2022 走看看