2.1<script> 元素

在HTML中添加JavaScript的主要方法,就是使用<script>元素。
HTML4.01为<script>添加了6个属性

① async: 可选,表示立即下载脚本,但是不妨碍页面中的其他操作,只对外部脚本文件有效
② charset: 可选, 表示通过src属性指定的代码的字符集,这个值已经很少有人用了,大多数的浏览器也会忽略它的值
③ defer: 可选,表示脚本可以延迟到文档完全被解析和显示之后执行。只对外部脚本文件有效,IE7及更早的版本对嵌入脚本也支持这个属性
④ language: 已废弃,表示编写代码使用的脚本语言
⑤ src: 可选, 表示包含要执行代码的外部文件
⑥ type: 可选, 表示编写代码使用的脚本语言的内容类型,MIME类型,默认值是 text/javascript

使用<script>元素的方式有两种
1、直接在页面中嵌入JavaScript代码

包含在<script>元素内部的JS代码会被从上到下的顺序依次执行,
在使用<script>嵌入JS代码时,不要在代码中的任何地方出现“</script>“字符串,否则就会被认为是结束的</script>标签。如果避免不了要使用可以通过转义字符“\”解决这个问题。

2、包含外部的JavaScript文件

如果要通过<script>元素来包含外部的JS文件,那么src属性就是必需的。这个属性就是指向外部JS的链接地址,例如:

 <script src="js/demo.js" type="text/javascript"></script>

这样外部文件demo.js就被加载到当前的页面中。
与解析嵌入式JS代码一样,在解析外部JS文件时,页面的处理会暂时停止。
需要注意的是,在带有src属性的<script>元素中不应该在其<script>与</script>之间在包含额外的JS代码,如果包含了,则会被忽略不执行。
只要不存在defer和async属性,浏览器就会按照<script>元素在页面中出现的先后顺序依次解析。

标签的位置

按照传统的做法,所有<script>元素都应该放在<head>元素中,这样使页面中所有外部文件的引用都放在相同的地方。前边说过,在JS文件加载解析时,页面会暂时停止,这样对于有很多JS的页面来说,会导致浏览器在呈现页面前出现明显的延迟,延迟期间,浏览器窗口是一边空白,这对于用户来说是很不友好的行为。
为了避免这个问题,现代的web应用程序都把全部JS引用放在<body>元素中页面内容的后面

<!DOCTYPE html>
<html>
  <head>
    <title>DEMO</title>
  </head>
  <body>
    <!--  页面内容 -->
    <script src="js/demo1.js" type="text/javascript"></script>
    <script src="js/demo2.js" type="text/javascript"></script>
  </body>
</html>

这样,页面的内容完全加载在浏览器之后,才会解析JS代码,很大程度上改善页面延迟的问题。

延迟脚本

(可忽略不看)
前边提到<script>标签的defer属性,为什么不添加defer属性,而是要把文件放在页面的后面?
添加defer属性,脚本会被延迟到整个页面都解析完毕之后再运行,相当于告诉浏览器立即下载,但延后执行
在HTML5规范中要求脚本按照他们出现的先后顺序执行,在现实中,延迟脚本并不一定会按照顺序执行,所以最好只包含一个延迟脚本。
defer属性只使用于外部的脚本文件,这一点在HTML5中明确规定,因此支持HTML5的实现会忽略给嵌入脚本设置的defer属性。所以,把延迟脚本放在页面底部仍然是最好的选择!

异步脚本

HTML5为<script>元素定义了async属性,与defer类似,都是用于改变处理脚本的行为,只适用于外部脚本文件,并告诉浏览器立即下载文件,与defer不同,标记async的脚本并不保证按照指定的先后顺序执行,因此,要确保脚本文件之间互不依赖。
指定async的目的是不让页面等待脚本下载和执行,从而异步加载页面其它内容,建议异步脚本不要在加载期间修改DOM

嵌入代码和外部文件

在HTML中嵌入Javascript代码虽然没有问题,但是一般认为最好的做法还是尽可能使用外部文件来包含Javascript代码。
引用外部文件,会有几个有点
1、可维护性,
2、可缓存,浏览器根据具体的设置缓存链接的所有外部Javascript文件
3、适应未来,

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,270评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,489评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,630评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,906评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,928评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,718评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,442评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,345评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,802评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,984评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,117评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,810评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,462评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,011评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,139评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,377评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,060评论 2 355

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,665评论 18 139
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,489评论 1 45
  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 4,149评论 0 13
  • 山西医科大学第二医院西院病理科 张凤 2017年9月7号,老公我儿子一家人来到了西安。儿子刚满三个月,憨憨可爱的样...
    尹二尹阅读 236评论 1 1
  • Headspace 是由冥想领域的专家 Andy Puddicombe 建立的一个指导人们如何冥想的平台,其官方 ...
    最美应用阅读 1,083评论 1 15