JavaScript高级程序设计基础(一)

一、JavaScripts实现

 ECMAScript 只是对实现这个规范描述的所有方面的一门语言的称呼,Web 浏览器只是 ECMAScript 实现可能存在的一种宿主环境

DOM 通过创建表示文档的树,让开发者可以随心所欲地控制网页的内容和结构。使用 DOM API
可以轻松地删除、添加、替换、修改节点

BOM用于支持访问和操作浏览器的窗口

二、HTML中的JavaScript

2.1<script>元素

  • async(可选):立即开始下载脚本,但只对外部脚本文件有效(不推荐使用)
  • defer(可选):脚本延迟到文档被完全解析和显示之后再执行,只对外部有效
  • integrity(可选):比对接收到的资源和指定的加密签名以验证子资源完整性
  • src(可选):外部文件,可接受不同域的。且一旦有src则不会执行行内代码
  • type(可选):示代码块中脚本语言的内容类型
注意: 在使用行内 JavaScript 代码时,代码中不能出现字符串 </script>
           浏览器不会检查所包含 JavaScript 文件的扩展名.js,但服务器会

2.1.1标签位置

将<script>标签放在head里容易出现页面长时间空白,因为 页面在浏览器解析到 <body>的起始标签时才开始渲染,所以现在会将<script>标签放在 <body> 元素中的页面内容后面

2.1.2 defer

立即下载,延迟执行。<script>元素会在浏览器解析到结束的</html>标签后才会执行,建议实际中只包含一个这样的脚本并放在页面底部

2.1.3动态加载脚本

let script = document.createElement('script'); 
script.src = 'gibberish.js'; 
script.async = false;
document.head.appendChild(script);

上述代码相当于将动态脚本加载行为设置为同步加载,为了不影响队列优先级,可让预加载器知道动态请求文件的存在

<link rel="preload" href="gibberish.js">

 2.2行内代码与外部文件

建议将js代码放在外部文件,因为浏览器会有特定的缓存,同样的js文件只会下载一次

当浏览器请求外部文件时,如果使用SPDY/HTTP2(预请求的消耗已显著降低),就可以从同一个地方取得一批文件,并将它们逐个放到浏览器缓存中。上述方式更加有利

如果是较老的浏览器,可能还是用大文件更加合适。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值