8 HTML其他

script,noscript

<script> 标签用于在网页插入脚本,<noscript> 标签用于指定浏览器不支持脚本时的显示内容。

script

<script> 用于加载脚本代码,目前主要是加载 JavaScript 代码。

<script>
	console.log('hello world');
</script>

<script> 也可以加载外部脚本,src 属性给出外部脚本的地址:

<script src="javascript.js"></script>

type 属性给出脚本的类型,默认是 JavaScript 代码,所以可省略。完整的写法其实是下面这样。

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

type 属性也可以设成 module,表示这是一个 ES6 模块,不是传统脚本。

<script type="module" src="main.js"></script>

对于那些不支持 ES6 模块的浏览器,可以设置 nomodule 属性。支持 ES6 模块的浏览器,会不加载指定的脚本。这个属性通常与 type="module" 配合使用,作为老式浏览器的回退方案。

<script type="module" src="main.js"></script>
<script nomodule src="fallback.js"></script>

<script> 还有下面一些其他属性,大部分跟 JavaScript 语言有关:

noscript

<noscript> 标签用于浏览器不支持或关闭 JavaScript 时,所要显示的内容。用户关闭 JavaScript 可能是为了节省带宽,以延长手机电池寿命,或者为了防止追踪,保护隐私。

<noscript>
  您的浏览器不能执行 JavaScript 语言,页面无法正常显示。
</noscript>

iframe

<iframe> 标签用于在网页里面嵌入其他网页。

基本用法

<iframe> 标签生成一个指定区域,在该区域中嵌入其他网页。它是一个容器元素,如果浏览器不支持 <iframe>,就会显示内部的子元素。

<iframe src="https://www.example.com"
        width="100%" height="500" frameborder="0"
        allowfullscreen sandbox>
  <p><a href="https://www.example.com">点击打开嵌入页面</a></p>
</iframe>

上面的代码在当前网页嵌入https://www.example.com,显示区域的宽度是 100%,高度是 500 像素。如果当前浏览器不支持> <iframe>,则会显示一个链接,让用户点击。

浏览器普遍支持 <iframe>,所以内部的子元素可以不写。

<iframe> 的属性如下。

sandbox 属性

嵌入的网页默认具有正常权限,比如执行脚本、提交表单、弹出窗口等。如果嵌入的网页是其他网站的页面,你不了解对方会执行什么操作,因此就存在安全风险。为了限制 <iframe> 的风险,HTML 提供了 sandbox 属性,允许设置嵌入的网页的权限,等同于提供了一个隔离层,即 " 沙箱 "。

sandbox 可以当作布尔属性使用,表示打开所有限制。

<iframe src="https://www.example.com" sandbox>
</iframe>

sandbox 属性可以设置具体的值,表示逐项打开限制。未设置某一项,就表示不具有该权限。

注意,不要同时设置 allow-scriptsallow-same-origin 属性,这将使得嵌入的网页可以改变或删除 sandbox 属性。

loading 属性

<iframe> 指定的网页会立即加载,有时这不是希望的行为。<iframe> 滚动进入视口以后再加载,这样会比较节省带宽。

loading 属性可以触发 <iframe> 网页的懒加载。该属性可以取以下三个值。

<iframe src="https://example.com" loading="lazy"></iframe>

有一点需要注意,如果 <iframe> 是隐藏的,则 loading 属性无效,将会立即加载。只要满足以下任一个条件,Chrome 浏览器就会认为 <iframe> 是隐藏的。