2.在HTML中使用JavaScript
1. script元素
向HTML中插入JavaScript的主要方法,就是使用script标签
HTML 4.01为script标签定义了6个属性
- async:可选,表示异步,立即下载脚本,但是不妨碍页面中其它操作。只对外部脚本文件有效
- charset:可选,表示通过src属性指定的代码的字符集。大多数浏览器会忽略他的值
- defer:可选, 表示脚本可以延迟到文档完全被解析之后再执行,只对外部文件有效
- language:已废弃,原用来表示编写代码所使用的脚本语言
- src:可选,表示要执行的代码外部文件
- type:可选,可以看成是language的代替属性,表示编写代码使用的脚本语言的内容类型。默认为 text/javascript
使用script标签的方式:直接在页面中嵌入JavaScript代码和包含外部文件
在使用script标签嵌入JavaScript代码时,需要为该标签指定type属性,然后将JavaScript代码放入即可
<script>
function sayHi(){
alert("Hi~")
}
<script>
注意:
如果要使用外部JavaScript文件,则script标签的src属性就是必须的,这个属性的值就是一个指向外部JavaScript文件的链接
<script type="text/javascript" src="example.js"></script>
在使用嵌入式JavaScript代码时,切忌不要在任何地方出现“script”字符串,因为浏览器会将其解析为结束标签
eg:错误的写法(会报错)
<script>
function sayScript(){
alert("</script>");
}
</script>
eg:正确的写法(通过转义字符转义)
<script>
function sayScript(){
alert("<\/script>");
}
</script>
- 包含在script标签中的代码,将会被从上到下依次解释
2. 标签的位置
按照传统的做法,所有的script标签都要放在页面的head标签中。
这种做法意味着页面要等全部的JavaScript代码都被下载和执行完成以后,才开始呈现页面的内容。这无疑会导致页面页面在加载的时候出现延迟。影响用户体验。为避免这个问题,现代的web应用程序一般把全部的JavaScript放在标签的最后面
<!DOCTYPE>
<html>
<head>
<title>Example Html page</title>
</head>
<body>
//...内容区
<script type="text/javascript" src="example1.js" ></script>
<script type="text/javascript" src="example2.js" ></script>
</body>
</html>
3.延迟和异步加载
defer属性:脚本会被延迟到整个页面都解析完成之后再运行,因此,在script标签中设置该属性,等于告诉浏览器,立即下载,延迟执行
async:只适用于外部脚本文件,并告诉浏览器立即下载文件,但是并不保证按照指定它们的先后顺序执行
4.嵌入代码与外部代码的区别
一般认为最好的做法还是尽可能使用外部文件来包含JavaScript代码
外部文件含有如下优点:
- 可维护性强
- 可缓存:如果有两个文件使用同一个JavaScript文件,那么该JavaScript文件只会被加载一次,可以加快页面加载速度
- 适应未来
5.noscript
元素
包含noscript
的元素只有在以下情况下才会显示出来
- 浏览器不支持脚本
- 浏览器支持脚本,但是脚本被禁用
只有符合以上条件,noscript
标签中的内容才会显示出来
<!DOCTYPE>
<html>
<head>
<title>Example Html page</title>
<script type="text/javascript" src="example1.js" ></script>
<script type="text/javascript" src="example2.js" ></script>
</head>
<body>
<noscript>
<p>
本页面需要浏览器支持(启用)JavaScript
</p>
</noscript>
</body>
</html>
这个页面会在脚本无效的情况下向用户展示一条信息。而在启用了脚本的浏览器中,用户永远也不会看到它,即使它是页面的一部分
6. 小结
- 包含外部的JavaScript文件的时候,
script
标签必须使用src属性指定外部文件链接 - 在不使用异步和延迟加载(async,defer)的情况下,所有script标签中的元素都会按照他们在文件中出现的顺序依次依次加载,只有解析完前面的
script
标签之后,才会解析后面的 - defer属性可以让脚本在文档完全呈现之后再去执行,延迟脚本总是按照他们的顺序执行
- async属性可以表示当前脚本不必等待其他脚本,也不必阻塞文档呈现,但是不能保证异步脚本按照他们原来的顺序
noscript
标签可以指定在不支持脚本的浏览器中显示替代的内容,但是在启用了脚本的浏览器中,浏览器不会显示该标签中的任何内容
2.在HTML中使用JavaScript的更多相关文章
- JavaScript高级程序设计-(1)html中使用JavaScript
html中使用JavaScript 1.延迟脚本 script标签定义了defer属性,脚本会被延迟到整个页面都解析完毕后运行 详细内容如下: 2.异步脚本 script标签定义了async属性,as ...
- 在HTML中使用JavaScript元素
script属性<script async = async charset="utf-8" defer="defer" src="index.h ...
- 2在HTML中使用JavaScript
像HTML页面中插入JavaScrip的主要方法,就是使用<script>元素.HTML4.01为<script>定义了6个属性:async:可选,表示应该立即下载脚本,当不妨 ...
- javascript高级编程3第二章:在html中使用javascript
2.1 <script>元素 向html页面中插入javascript的主要方法,就是使用<script>元素.这个元素被加入到正式的html规范中.html4.01为< ...
- JS高程2.在HTML中使用Javascript(1)
1.使用<script>元素向HTML页面中插入Javascript HTML4.01中<script>标签有6个属性: (1)async:可选.表示立即下载脚本,不影响页面中 ...
- 在Swift中使用JavaScript的方法和技巧
本文作者Nate Cook是一位独立的Web及移动应用开发者,是继Mattt大神之后NSHipster的主要维护者,也是非常知名活跃的Swift博主,并且还是支持自动生成Swift在线文档的Swift ...
- js002-在HTML中使用JavaScript
js002-在HTML中使用JavaScript 2.1 <script>元素 定义了以下6个属性 async: 可选.表示应该立即下载脚本,但不妨碍页面中的 ...
- Javascript高级程序设计——在HTML中使用Javascript
<script>元素 向HTML页面中插入Javascript的主要方法,就是使用<script>元素,<script>元素有六个属性: async:可选.表示应该 ...
- 2. javacript高级程序设计-在HTML中使用JavaScript
1.1 <script>元素 向HTML页面中插入JavaScript的主要方法,就是使用<script>元素,<script>元素定义了一下6个元素: (1). ...
- js-js实现,在HTML中使用JavaScript,基本概念
Js实现: 1.JavaScript实现的组成: 核心(ECMAScript):由ECMA-262定义,提供核心语言功能 文档对象模型(DOM)提供访问和操作网页内容的方法以及接口 浏览器对象模型(B ...
随机推荐
- 003 okhttp超时与缓存
上文的介绍都没添加,如果要添加,则按照下面的方式设置. File sdcache = getExternalCacheDir(); int cacheSize = 10 * 1024 * 1024; ...
- Session覆盖测试(要验证码提交到后续页面操作的 绕过去的场景)
测试原理和方法 找回密码逻辑漏洞测试中也会遇到参数不可控的情况,比如要修改的用户名或者绑定 的手机号无法在提交参数时修改,服务端通过读取当前session会话来判断要修改密码的账 号,这种情况下能否对 ...
- EasyDSS高性能RTMP、HLS(m3u8)、HTTP-FLV、RTSP流媒体服务器解决方案之Windows服务安装
背景说明 EasyDSS流媒体解决方案是由安徽旭帆信息科技有限公司自主研发的一套集流媒体点播.转码.管理.直播.录像.检索.时移回看于一体的一套完整的商用流媒体解决方案.EasyDSS软件以压缩包的形 ...
- [Metricbeat] Metricbeat监控golang服务器
0x0 前言 最近这几天研究了一下ElasticSearch相关的技术栈.前面一篇转发了别人些的非常详细的ElasticSearch和Kibana搭建的过程.发现Elastic家族还有Metricbe ...
- 【C/C++开发】C++之enum枚举量声明、定义、使用与枚举类详解与枚举类前置类型声明
众所周知,C/C++语言可以使用#define和const创建符号常量,而使用enum工具不仅能够创建符号常量,还能定义新的数据类型,但是必须按照一定的规则进行,下面我们一起看下enum的使用方法. ...
- activiti学习5:开启流程和流程前进
目录 activiti学习5:开启流程和流程前进 一.流程和任务的关系 二.开启流程 2.1根据流程定义key开启流程 三.查询用户任务 3.1 TaskQuery 四.完成任务 activiti学习 ...
- Endpoint is unreachable and there is no snapshot available for offline browsing
docker Portainer配置的时候出现这个错误:Endpoint is unreachable and there is no snapshot available for offline b ...
- Python的基本数据类型2
1.str(字符串) 1.切片 str = "你好,我是Python" s = str[0:4] #用法[start:end:step],指定开始下标和结束下标,step是步长,默 ...
- day53——标签操作
day53 今日内容 标签操作 值操作 取值: 文本输入框:$('#username').val(); input,type=radio单选框: $('[type="radio"] ...
- B站动态转发抽奖脚本+教程
运行python脚本需要的条件: 1.连通的网络 2.已安装Python2并配置环境变量 3.Python脚本源码 环境搭建: 网络就不用我说了("'▽'") 那么下面我们来安装 ...