前端入门——在网页中使用JavaScript
myzbx 2024-12-12 13:35 30 浏览
在JavaScript诞生之初Netscape 浏览器要解决一个重要的问题就是如何让JavaScript和html页面共存,经过尝试、争论最终决定为web增加统一的脚本支持,并被正式纳入HTML规范之中。
本篇主要介绍如何在html网页中使用<script> 标签元素引入脚本,关于<script>元素有以下属性:
- src:可选,表示引入的外部js文件。
- type:可选,表示编写代码的脚本语言内容类型(MIME类型)。目前此属性都使用text/javascript,这个属性值也是默认的值,如果不设置type属性就使用这个默认值。除此之外也可以使用 text/ecmascript或 application/javascript等,因为各浏览器兼容性问题,在此不建议使用。
- language:已废弃。早期用来表示脚本语言类型,比如(JavaScript、JavaScript1.2或VBScript),现已不再使用。
- charset:可选。表示通过src指定的代码的字符集。大多数浏览器会忽略这个属性,因此很少使用。
- defer:可选。表示脚本延迟到文档完全被解析和显示后再执行。只有在加载外部js文件时才可用。
- async:可选。表示应该立即下载脚本,但不阻碍页面其它部分的操作,比如下载其它资源或等待加载其它脚本。只有在加载外部js文件时才可用。
脚本使用方法
一般都会在<head>元素中使用<script>标签,分别有内嵌式脚本和外部脚本两种用法,具体如下:
内嵌式:
<html>
<head>
<script type="text/javascript">
function hello(){
alert('hello world!')
}
hello();
</script>
</head>
<body></body>
</html>
如上面的代码,内嵌式就是将js代码写在<script>标签内,这里的type属性可以省略。
外部脚本:
<html>
<head>
<script type="text/javascript" src="hello.js"></script>
</head>
<body></body>
</html>
如上代码,外部脚本通过src属性引入,这里的src属性和img图片的src一样,它的值是一个URL,可以使相对路径,绝对路径,甚至是来自第三方域的地址。
外部脚本的优点就是,它可以把不同业务的代码放入到指定的外部js文件中,依次引入到页面,这样当页面的业务逻辑复杂时便于管理组织代码。如今,在各现代浏览器中已经部分支持原生的模块语法,意味着可以在js文件中直接引入其它js文件,关于模块化后期再单独介绍。
script标签的位置
默认情况下,浏览器会按照script标签在页面中出现的顺序从前到后依次进行解析。也就是说,后面的script要等前面的script解析完后再执行。所以有时就会因为脚本错误,导致页面无法继续往下执行,页面就会出现空白或显示部分,所以一般约定将script标签放在</body>标签之前,这样即使脚本出错,也不会影响html的解析。
如下示例:
<html>
<head>
</head>
<body>
<p>引入外面脚本文件</p>
<script type="text/javascript" src="demo1.js"></script>
<script type="text/javascript" src="demo2.js"></script>
</body>
</html>
把脚本放在最后,还有个好处就是使页面打开的速度变快,这是因为js脚本的解析是同步的,会阻塞后面的代码。
延迟脚本
使用defer属性延迟脚本,这个属性的用途是指在脚本执行时不会影响页面html或css的解析。直到整个页面解析完毕后再运行。因此,defer属性就是告诉浏览器立即下载js文件,但延迟执行它。
如下示例:
<html>
<head>
<script type="text/javascript" defer="defer" src="demo1.js"></script>
<script type="text/javascript" defer="defer" src="demo2.js"></script>
</head>
<body>
<p>延迟引入外面脚本文件</p>
</body>
</html>
在这个例子中,虽然脚本放在head元素中,但其包含的脚本会延迟到浏览器解析完整个页面后才执行。这里要注意,html5 规范中要求脚本按照先后顺序执行,理论上第一个延迟脚本会先于第二个,但是实际情况并不是这样的,因此一般页面中尽量只有一个延迟脚本。关于延迟脚本,后面会继续详细介绍。
前面说过,defer属性只对外部脚本起作用,内嵌式不支持,除非早期的ie浏览器才支持,在这里不再具体探讨,毕竟是过时的东西,没必要学习。
异步脚本
和延迟脚本一样,使用async可以改变处理脚本的行为。异步脚本只适用于外部js文件,它表示告诉浏览器立即下载文件,和defer不同之处就是异步脚本不保证会按照先后顺序执行脚本。
如下示例:
<html>
<head>
<script type="text/javascript" async src="demo1.js"></script>
<script type="text/javascript" async src="demo2.js"></script>
</head>
<body>
<p>异步加载脚本文件</p>
</body>
</html>
上面代码中,第二脚本可能会在第一个脚本文件之前执行。因此保证它们相互之间不依赖非常重要。
建议异步脚本不要在加载中修改DOM,在xhtml文档中使用async=“async”才起作用。
<noscript>元素
早期浏览器面临一个特殊的情况,就是当浏览器不支持JavaScript时如何让页面平稳的显示。因此为了解决这个问题创造了一个<noscript>元素,用来在不支持JavaScript时在页面中显示代替的内容。这个元素中可以包含任何html元素,除了<script>外。
当浏览器禁用JavaScript时,也可以使用这个标签,如下示例:
<html>
<head>
<script type="text/javascript" async src="demo1.js"></script>
<script type="text/javascript" async src="demo2.js"></script>
</head>
<body>
<noscript>本页面需要浏览器支持或启用JavaScript。</noscript>
</body>
</html>
在不支持或禁用JavaScript的浏览器页面中就会看到上面这段文字。
总结
在html页面中使用<script>标签可以使用嵌入式或外部js文件,这里我们要注意几点:
- 在包含外部脚本文件时,必须将src属性设置为指向相应的文件URL。这个文件可以是同一个服务器上的或其它域中的文件。
- 所有<script>元素都会按照在页面中出现的先后顺序被依次解析。在不适应延迟或异步属性时,只有在所有<script>标签代码解析完后,才继续后面的代码。
- 将<script>元素放在页面最后,即body结束标签之前。
- 使用defer属性延迟脚本在页面完全呈现之后再执行。延迟脚本一般会按照顺序执行。
- 使用async异步加载脚本,表示脚本不必等待其它脚本,也不会阻塞文档呈现。但异步脚本不能保证按照先后顺序执行。
- <noscript>元素,在不支持JavaScript或禁用JavaScript的浏览器中显示替代内容。
本文主要介绍了,JavaScript的基本使用方法,详细介绍了<script>元素的语法,后面我们将正式开始JavaScript学习,JavaScript的语法是一个类似c语言或其它高级语言(如java、perl等),如果你有其它语言的基础,学习起来非常容易。
感谢您的关注,欢迎指正。
相关推荐
- 砌体植筋拉拔试验检验值到底是6.0KN,还是10.2KN,如何计算确定
-
砌体拉结筋植筋养护完成后,需对所植钢筋进行拉拔试验,以检验植筋的锚固强度是否满足设计要求。检测时,按照一定的抽样比例进行拉拔试验。根据《混凝土结构后锚固技术规程》JGJ145-2013,以同品种、同...
- 柴油机功率如何计算?计算柴油机功率需要哪些参数?
-
在汽车领域,对于柴油机功率的计算是一项重要的工作,它有助于我们更好地了解柴油机的性能和适用场景。下面我们就来详细探讨一下柴油机功率的计算方法以及所需的参数。首先,我们要了解计算柴油机功率常用的公式。在...
- 变压器短路阻抗的作用和计算方法(变压器短路阻抗的作用和计算方法是什么)
-
变压器短路阻抗的作用和计算方法短路阻抗是在负载试验中测量的一项数据,它是二次侧短接并流过额定电流时,一次侧施加的电压与额定电压的的百分数。那么测量变压器的短路阻抗有什么意义呢?其实变压器的阻抗电压乃是...
- 9.35m层高高支模支撑架计算书(支模架多高属于高支模)
-
某工厂新扩建的建筑面积为1989.2m^2,建筑物总体分为2层,但局部为4层。建筑物檐高19.4m,建筑物总高23m。建筑物呈长方形设置,长度为48.20m,宽度为23.88m,结构形式为框架结构...
- 吊篮(悬挂装置前梁加长)安全复核计算书
-
吊篮(悬挂装置前梁加长)安全复核计算书一种超常规搭设的高处作业吊篮,因使用要求将吊篮悬挂装置前梁加长设置,本计算书针对这种工况的校核,以作参考。计算依据:1、《高处作业吊篮》GB/T19155-...
- 电功率计算公式精编汇总(电功率计算视频讲解)
-
一、电功率计算公式:1在纯直流电路中:P=UIP=I2RP=U2/R式中:P---电功率(W),U---电压(V),I----电流(A),R---电阻(Ω)。2在单相交流电路中:P=UIcosφ...
- 灌注桩承载力检测方法及步骤(灌注桩承载力不够怎么办)
-
检测灌注桩的承载力是确保基础工程安全可靠的关键环节,检测结果的精细能准确为我们提供可靠的数据,让我们能准确判断桩基础的承载力,方便后续施工安排,同样也能让我们根据数据分辨出有问题桩基,采取可靠有效的措...
- 很哇塞的体积计算方法:向量叉乘 很哇塞的体积计算方法
-
高中数学必看:向量叉乘,体积的神。大家都知道a、b的向量是什么意思,但是a、b的向量又是什么?很多同学都不知道,向量的向量在高中阶段非常有用,虽然它是大学的知识,在高中阶段可以干两件事。·第一件事,表...
- 施工升降机基础(设置在地库顶板回顶)计算书
-
施工升降机基础(设置在地库顶板回顶)计算书计算依据:1、《施工现场设施安全设计计算手册》谢建民编著2、《建筑地基基础设计规范》GB50007-20113、《混凝土结构设计标准》GB/T50010-2...
- 剪力墙水平钢筋根数如何计算?(剪力墙水平钢筋绑扎搭接规范)
-
剪力墙水平钢筋根数的计算需综合考虑墙高、起步距离、间距及构造要求等因素,具体步骤如下及依据:1.基本计算公式水平钢筋根数计算公式为:根数=(墙高-起步距离)/间距(墙高-起步距离)/间距...
- 直流电路常用计算公式(直流电路常用计算公式有哪些)
-
1、电阻导体阻碍电流通过的能力叫做电阻,用字母R表示,单位欧(Ω)。R=ρl/s式中R-导体的电阻,欧(Ω);ρ-导体的电阻率,欧·米(Ω·m);l-导体的长度,米(m);s-导体的截面积,平方米(m...
- 电气主电路图的绘制特点(电气原理图主电路)
-
1、电气主电路图中的电气设备、元件,如电源进线、变压器、隔离开关、断路器、熔断器、避雷器等都垂直绘制,而母线则水平绘制。电气主电路图除特殊情况外,几乎无一例外地画成单线图,并以母线为核心将各个项目(如...
- 中考总复习:物理专题 功和机械能 (功的计算、功率、动能、势能)
-
中考物理专题:功与机械能解析一、力学中的功——能量转化的桥梁功是力对物体能量变化的量度,需满足两要素:作用在物体上的力、物体沿力方向移动距离。例如推箱子时,若箱子未移动,推力不做功;若箱子滑动,推力做...
- 40亿QQ号,不超过1G内存,如何去重?
-
分享一道网上很火的面试题:40亿QQ号,不超过1G的内存,如何去重?这是一个非常经典的海量数据去重问题,并且做了内存限制,最多只能1GB,本文跟大家探讨一下~~一、常规思路我们日常开发中,如果谈到去重...
- 填充墙体拉结筋植筋深度、孔径、拉拔试验承载力计算!
-
今天分享下植筋间距及保护层要求:根据JGJ145-2013混凝土后锚固技术规程要求植筋与混凝土结构边缘不应小于5mm,植筋为两根及以上时水平间距为不应小于5d(d为钢筋直径)。根据混凝土结构后锚固技...
- 一周热门
- 最近发表
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)
- JS Loop For (32)