使用Javascript

我们在使用js代码时,是怎么在HTML中使用的呢,下面由小小博主带来一段小路程。


文章目录

< script > 元素

在使用js时,主要就是在HTML中使用此元素。在HTML4.01为此元素定义6个属性。

async:可选。表示应该立即下载脚本,但不应妨碍页面中的其它操作,只对外部脚本文件有效。
charset:可选。表示通过src属性指定的代码的字符集。由于大多数浏览器会忽略它,所以很少有人使用。
defer:可选。表示脚本可以延迟到文档完全被解析和显示之后再执行。只对外部脚本文件有效。IE7>...也支持。
language:已废。
src:可选,表示包含要执行的外部文件。
type:可选。可看成是language的替代品,表示编写代码使用的脚本语言的内容类型(也称为MIME类型)一般是text/javascript,但是可以不写,它就会默认text/javascript,在服务器传javascirpt文件时使用的是application/x-javascript,但是考虑到在type上使用这个的话可能被忽略的可能,而且在非IE浏览器上又不是使用的是这个,所以一般使用text/javascript。

使用方式有两种:外部引入和嵌入式。

1、嵌入式只需指定type属性即可。
		注意:
			(1)js代码是从上至下依次解释。
			(2)不要在任何地方出现"</script>"字符串,因为这样浏览器会认为这是个结束标签,最简单办法是转义,这就是为啥我们写网页的时候要防止XSS攻击的原因。
2、外部引入,指定src和type属性。
		注意:
			(1)我们引入的文件它会放在<script> ....</script>里执行,在解析外部文件时(包含下载该文件),页面的处理也会暂时停止。这就是为啥我们会把css文件放在body前,把js文件放在body后的原因。
			(2)在XHTML文档中可使用<script  ... />这种样式,但是在HTML文档中不能,因为不符合HTML规范,而且得不到全部浏览器的正确解析(尤其IE)。
			(3)外部js文件一般是带有.js扩展名的,但是这个是不必须的,因为浏览器不会检查扩展名,我们可以使用JSP、PHP也是可以的,但是这样就要确保服务器能够返回正确的MIME类型。
			(4)在<script> ...</script>还有嵌入代码,则会被忽略,我们可以理解为当我们引入外部代码时把里面的代码替换掉了。
			(5)<script src="...">可以引入外部域的文件,但是我们必须确保这个外部域是可信的或者你是这个域的所有者,这就是为啥跨域请求中可以用这个来做的原因。
			(6)浏览器会在第一个<script>元素包含代码执行完后再执行第二个<script>,这也是为啥我们会有次序的引入js文件的原因。

延迟脚本

定义defer属性

<script defer="defer"></script>

意思是说告诉浏览器立即下载,但延迟执行。

谈到这可能会想,不是说浏览器会一行一行的执行代码吗,且这个js文件在body的后面,浏览器怎么会知道立即执行呢?
答:这个是因为它有个预编译的阶段,这个阶段会粗滤的扫描代码一篇,在<script>元素上扫描到了defer,它不就知道了吗。或者直接把<script>放在head元素中,这样就更好理解了。
		注意:
			1、HTML5规范要求脚本按照他们出现的先后顺序执行,并先于DOMContentLoaded事件,但是现实中,延迟脚本不一定,也不一定在DOMContentLoaded前执行,因此最好只有一个延迟脚本。
			2、HTML5的实现会忽略defer属性,但是有些浏览器又不会,所以我们在写程序时最好把它放在页面底部。
			3、在XHTML文档中,我们要写成defer="defer"。

异步脚本

与defer属性相似的就是async属性。

使用时注意:
		(1)两个<script>元素引入的文件不要互相依赖,因为加上async后不能确定那个先执行。
		(2)引入的文件不要在加载期间操作DOM,因为async是在不等待页面加载的时候段加载,从而异步加载js。
		(3)异步脚本一定会在页面load事件前执行,可能在DOMContentLoaded前后执行。
		(4)在XHTML文档中,写成async="async"。

文档模式

最初文档模式:混杂模式标准模式

标准模式开启

//4.01
<!doctype html public "-//w3c//dtd html 4.01//en" "http://www.w3.org/tr/html4/strict.dtd">

//1.0
<!doctype html public "-//w3c//dtd xhtml 1.0 strict//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-strict.dtd">

//html5
<!doctype html>

还有一个准标准模式,通过使用过滤型或框架集型文档类型来触发的…
而且准标准模式和标准模式非常接近,我们一般提到标准模式,指的是除混杂模式外的其它模式。
还有一点就是:noscript元素,用于浏览器不支持javascript,现在一般很少使用这个

over~ ~ ~

上一篇:非零基础速成Go语言_基础篇


下一篇:Golang知识点七、defer