金沙澳门唯一官网:简单介绍HTML5中的文件导入

2019-11-04 11:26 来源:未知

HTML imports 入门

2015/02/10 · HTML5 · HTML, imports

本文由 伯乐在线 - XfLoops 翻译,周进林 校稿。未经许可,制止转发!
俄语出处:webcomponents.org。接待参加翻译组。

Template、Shadow DOM及Custom Elements 让你创设UI组件比原先更便于了。不过像HTML、CSS、JavaScript那样的财富如故必要叁个个地去加载,那是很没作用的。

删去重复信赖也并不轻松。比如,今后加载jQuery UI或Bootstrap就须要为JavaScript、CSS及Web Fonts加多单独的价签。要是你的Web 组件应用了三翻五次串的依靠,那事情就变得愈加复杂。

HTML 导入让您以贰个联合的HTML文件来加载那个财富。

粗略介绍HTML5中的文件导入,

那篇小说首要介绍了简便介绍HTML中的文件导入,包含加载jQuery、导入后的施行顺序等知识点,需求的对象能够参谋下

Template、Shadow DOM及Custom Elements 让您创建UI组件比早先更易于了。不过像HTML、CSS、JavaScript那样的财富还是供给一个个地去加载,那是很没作用的。

除去重复信赖也并不轻便。比方,今后加载jQuery UI或Bootstrap就必要为JavaScript、CSS及Web Fonts增加单独的竹签。如若您的Web 组件应用了层层的注重性,那件事情就变得更加的复杂。

HTML 导入让你以多少个群集的HTML文件来加载那么些能源。
使用HTML导入

为加载叁个HTML文件,你供给追加三个link标签,其rel属性为import,herf属性是HTML文件的路径。举个例子,纵然你想把component.html加载到index.html:

index.html  

XML/HTML Code复制内容到剪贴板

  1. <link rel="import" href="component.html" >    

你可以后HTML导入文本(译者注:本文将“ the imported HTML”译为“HTML导入文本”,将“the original HTML”译为“HTML主文件”。比如,index.html是HTML主文件,component.html是HTML导入文本。卡塔 尔(英语:State of Qatar)增多任何的财富,饱含剧本、样式表及字体,就跟往普通的HTML加多能源同样。

component.html  

XML/HTML Code复制内容到剪贴板

  1. <link rel="stylesheet" href="css/style.css">  
  2. <script src="js/script.js"></script>  

doctype、html、 head、 body这个标签是不需求的。HTML 导入会即刻加载要导入的文书档案,深入分析文书档案中的财富,假若有脚本的话也会及时实践它们。
实行顺序

浏览器剖判HTML文书档案的不二等秘书诀是线性的,那就是说HTML顶上部分的script会比尾部先实践。何况,浏览器常常会等到JavaScript代码试行实现后,才会随着解析后边的代码。

为了不让script 妨碍HTML的渲染,你能够在标签中增加async或defer属性(或许您也足以将script 标签放到页面包车型客车底层卡塔尔国。defer 属性会延迟脚本的实行,直到整个页面分析完结。async 属性让浏览器异步地进行脚本,进而不会妨碍HTML的渲染。那么,HTML 导入是如何专门的学问的吗?

HTML导入文本中的脚本就跟含有defer属性相近。比方在底下的以身作则中,index.html会先进行script1.js和script2.js ,然后再推行script3.js。

index.html  

XML/HTML Code复制内容到剪贴板

  1. <link rel="import" href="component.html"> // 1.   
  2. <title>Import Example</title>  
  3. <script src="script3.js"></script>        // 4.  

component.html  

XML/HTML Code复制内容到剪贴板

  1. <script src="js/script1.js"></script>     // 2.   
  2. <script src="js/script2.js"></script>     // 3.  

1.在index.html 中加载component.html并等候实践

2.执行component.html中的script1.js

3.执行完script1.js后执行component.html中的script2.js

4.推行完 script2.js进而实行index.html中的script3.js

注意,如果给link[rel="import"]增多async属性,HTML导入会把它充作含有async属性的脚本来对待。它不会等待HTML导入文本的实行和加载,那代表HTML 导入不会妨碍HTML主文件的渲染。那也给提拔网站品质带给了恐怕,除非有别的的台本信任于HTML导入文本的实行。
跨域导入

从根本上说,HTML导入是不能从别的的域名导入财富的。

譬喻说,你不可能从 导入HTML 文件。为了绕过这一个节制,能够运用CO奥迪Q3S(跨域财富分享卡塔 尔(阿拉伯语:قطر‎。想精通CO福睿斯S,请看那篇小说。
HTML导入文本中的window和document对象

前方笔者提过在导入HTML文件的时候里面包车型客车脚本是会被施行的,但那并不表示HTML导入文本中的标签也会被浏览器渲染。你必要写一些JavaScript代码来支援。

当在HTML导入文本中应用JavaScript时,有少数要防备的是,HTML导入文本中的document对象实际指的是HTML主文件中的document对象。早先边的代码为例,index.html和  component.html 的document都以指index.html的document对象。怎么工夫动用HTML导入文本中的document 呢?依附link中的import 属性。

index.html  

XML/HTML Code复制内容到剪贴板

  1. var link = document.querySelector('link[rel="import"]');   
  2. link.addEventListener('load', function(e) {   
  3.   var importedDoc = link.import;   
  4.   // importedDoc points to the document under component.html   
  5. });  

为了得到component.html中的document 对象,要利用document.currentScript.ownerDocument.

component.html  

XML/HTML Code复制内容到剪贴板

  1. var mainDoc = document.currentScript.ownerDocument;   
  2. // mainDoc points to the document under component.html  

假如您在用webcomponents.js,那么就用document._currentScript来顶替document.currentScript。下划线用于填充currentScript属性,因为并非富有的浏览器都帮忙那么些天性。

component.html

 

XML/HTML Code复制内容到剪贴板

  1. var mainDoc = document._currentScript.ownerDocument;   
  2. // mainDoc points to the document under component.html   

因此在本子起头加多下边包车型大巴代码,你就足以轻巧地访谈component.html中的document对象,而不用管浏览器是还是不是永葆HTML导入。

document._currentScript = document._currentScript || document.currentScript;
性情方面包车型客车思虑

选择HTML 导入的四个收益是能力所能达到将财富集团起来,不过也意味着在加载这么些能源的时候,由于使用了有个别相当的HTML文件而让底部变得过大。有几点是急需思忖的:
剖判依赖

倘诺HTML主文件要正视多个导入文本,并且导入文本中隐含雷同的库,当时会怎么着呢?举个例子,你要从导入文本中加载jQuery,假设各样导入文本都带有加载jQuery的script标签,那么jQuery就能够被加载一次,并且也会被试行三遍。

index.html  

XML/HTML Code复制内容到剪贴板

  1. <link rel="import" href="component1.html">  
  2. <link rel="import" href="component2.html">  

component1.html  

XML/HTML Code复制内容到剪贴板

  1. <script src="js/jquery.js"></script>  

component2.html
 
HTML导入自动帮您消除了这些主题素材。

与加载四回script标签的做法不风度翩翩,HTML 导入对曾经加载过的HTML文件不再举行加载和实践。早前边的代码为例,通过将加载jQuery的script标签打包成三个HTML导入文本,那样jQuery就只被加载和施行一遍了。

但那还应该有二个难题:大家扩张了叁个要加载的文件。怎么管理数据膨胀的文书呢?幸运的是,我们有一个叫vulcanize的工具来减轻那个难题。
统一网络诉求

Vulcanize 能将七个HTML文件归并成二个文件,进而收缩了网络连接数。你能够凭仗npm安装它,并且用命令行来使用它。你只怕也在用 grunt和gulp 托管一些职务,那样的话你能够把vulcanize作为营造进度的一片段。

为了剖析注重以致联合index.html中的导入文本,使用如下命令:

代码如下:$ vulcanize -o vulcanized.html index.html

透超过实际行那几个命令,index.html中的注重会被剖判,并且会发生二个统生机勃勃的HTML文件,称作 vulcanized.html。学习更多关于vulcanize的知识,请看这儿。

介意:http2的服务器推送功用被寻思用于以往消逝文件的联网与联合。
把Template、Shadow DOM、自定义成分跟HTML导入结合起来

让我们对那一个稿子类别的代码应用HTML导入。你前边大概未有看过那么些小说,笔者先解释一下:Template能够令你用注解的方式定义你的自定义元素的内容。Shadow DOM能够让三个要素的style、ID、class只效劳到其本身。自定义成分得以让您自定义HTML标签。通过把那个跟HTML导入结合起来,你自定义的web 组件会变得模块化,具有复用性。任何人加多三个Link标签就足以行使它。

x-component.html

 

XML/HTML Code复制内容到剪贴板

  1. <template id="template">  
  2.   <style>  
  3.     ...   
  4.   </style>  
  5.   <div id="container">  
  6.     <img src=";  
  7.     <content select="h1"></content>  
  8.   </div>  
  9. </template>  
  10. <script>  
  11.   // This element will be registered to index.html   
  12.   // Because `document` here means the one in index.html   
  13.   var XComponent = document.registerElement('x-component', {   
  14.     prototype: Object.create(HTMLElement.prototype, {   
  15.       createdCallback: {   
  16.         value: function() {   
  17.           var root = this.createShadowRoot();   
  18.           var template = document.querySelector('#template');   
  19.           var clone = document.importNode(template.content, true);   
  20.           root.appendChild(clone);   
  21.         }   
  22.       }   
  23.     })   
  24.   });   
  25. </script>  

index.html  

XML/HTML Code复制内容到剪贴板

  1. ...   
  2.   <link rel="import" href="x-component.html">  
  3. </head>  
  4. <body>  
  5.   <x-component>  
  6.     <h1>This is Custom Element</h1>  
  7.   </x-component>  
  8.   ...  

瞩目,因为x-component.html 中的document 对象跟index.html的同样,你没供给再写一些险象环生的代码,它会自行为你注册。
支持的浏览器

Chrome 和 Opera提供对HTML导入的支撑,Firefox要在二〇一四年11月后才支撑(Mozilla表示Firefox不安顿在近来提供对HTML导入的扶持,声称须要首先精通ES6的模块是何许落成的卡塔尔。

您能够去chromestatus.com或caniuse.com查询浏览器是不是扶持HTML导入。想要在其余浏览器上行使HTML导入,能够用webcomponents.js(原名platform.js卡塔尔。
连带能源

HTML导入就介绍这么多了。要是您想学更加多关于HTML导入的学问,请前往:

    HTML Imports: #include for the web – HTML5Rocks
金沙澳门唯一官网,    HTML Imports spec

 

那篇文章主要介绍了总结介绍HTML中的文件导入,富含加载jQuery、导入后的施行顺序等知识点,必要的爱侣能够参...

使用HTML导入

为加载叁个HTML文件,你须要追加三个link标签,其rel属性为import,herf属性是HTML文件的路径。比方,要是您想把component.html加载到index.html:

index.html

XHTML

<link rel="import" href="component.html" >

1
<link rel="import" href="component.html" >

你可未来HTML导入文本(译者注:本文将“ the imported HTML”译为“HTML导入文本”,将“the original HTML”译为“HTML主文件”。比如,index.html是HTML主文件,component.html是HTML导入文本。卡塔尔国增多任何的财富,包括剧本、样式表及字体,就跟往普通的HTML加多能源同样。

component.html

XHTML

<link rel="stylesheet" href="css/style.css"> <script src="js/script.js"></script>

1
2
<link rel="stylesheet" href="css/style.css">
<script src="js/script.js"></script>

doctype、html、 head、 body那个标签是没有供给的。HTML 导入会立刻加载要导入的文书档案,解析文书档案中的能源,假使有脚本的话也会及时实施它们。

施行顺序

浏览器解析HTML文书档案的方法是线性的,那正是说HTML顶上部分的script会比尾巴部分先实践。况兼,浏览器平日会等到JavaScript代码实践完成后,才会跟着解析后边的代码。

为了不让script 妨碍HTML的渲染,你能够在标签中增加async或defer属性(或许您也得以将script 标签放到页面包车型大巴底层卡塔 尔(英语:State of Qatar)。defer 属性会延迟脚本的奉行,直到全体页面深入分析实现。async 属性让浏览器异步地推行脚本,从而不会妨碍HTML的渲染。那么,HTML 导入是什么工作的吗?

HTML导入文本中的脚本就跟含有defer属性相近。比如在底下的身体力行中,index.html会先实行script1.js和script2.js ,然后再实行script3.js。

index.html

XHTML

<link rel="import" href="component.html"> // 1. <title>Import Example</title> <script src="script3.js"></script> // 4.

1
2
3
<link rel="import" href="component.html"> // 1.
<title>Import Example</title>
<script src="script3.js"></script>        // 4.

component.html

XHTML

<script src="js/script1.js"></script> // 2. <script src="js/script2.js"></script> // 3.

1
2
<script src="js/script1.js"></script>     // 2.
<script src="js/script2.js"></script>     // 3.

1.在index.html 中加载component.html并等待推行

2.执行component.html中的script1.js

3.执行完script1.js后执行component.html中的script2.js

4.实践完 script2.js继而实践index.html中的script3.js

注意,如果给link[rel=”import”]增加async属性,HTML导入会把它充当含有async属性的脚本来对待。它不会等待HTML导入文本的施行和加载,那意味HTML 导入不会妨碍HTML主文件的渲染。那也给提拔网址质量带给了也许,除非有别的的脚本信任于HTML导入文本的实施。

跨域导入

从根本上说,HTML导入是不能够从别的的域著名发行人入财富的。

举个例子,你不可能从向  导入HTML 文件。为了绕过这一个范围,能够行使COQX56S(跨域财富共享卡塔尔。想打听COENCORES,请看那篇作品。

HTML导入文本中的window和document对象

前方小编提过在导入HTML文件的时候里面包车型大巴脚本是会被实施的,但那并不意味HTML导入文本中的标签也会被浏览器渲染。你须求写一些JavaScript代码来提携。

当在HTML导入文本中运用JavaScript时,有几许要严防的是,HTML导入文本中的document对象实际指的是HTML主文件中的document对象。在此以前边的代码为例,index.html和  component.html 的document都以指index.html的document对象。怎么手艺利用HTML导入文本中的document 呢?依据link中的import 属性。

index.html

XHTML

var link = document.querySelector('link[rel="import"]'); link.addEventListener('load', function(e) { var importedDoc = link.import; // importedDoc points to the document under component.html });

1
2
3
4
5
var link = document.querySelector('link[rel="import"]');
link.addEventListener('load', function(e) {
  var importedDoc = link.import;
  // importedDoc points to the document under component.html
});

为了赢得component.html中的document 对象,要利用document.currentScript.ownerDocument.

component.html

XHTML

var mainDoc = document.currentScript.ownerDocument; // mainDoc points to the document under component.html

1
2
var mainDoc = document.currentScript.ownerDocument;
// mainDoc points to the document under component.html

万生机勃勃您在用webcomponents.js,那么就用document._currentScript来代替document.currentScript。下划线用于填充currentScript属性,因为实际不是独具的浏览器都帮忙这一个天性。

component.html

XHTML

var mainDoc = document._currentScript.ownerDocument; // mainDoc points to the document under component.html

1
2
var mainDoc = document._currentScript.ownerDocument;
// mainDoc points to the document under component.html

因此在剧本开始加多下边包车型客车代码,你就足以轻松地探问component.html中的document对象,而不用管浏览器是否援救HTML导入。

XHTML

document._currentScript = document._currentScript || document.currentScript;

1
document._currentScript = document._currentScript || document.currentScript;

品质方面包车型地铁设想

使用HTML 导入的叁个好处是能力所能达到将资源公司起来,但是也象征在加载这一个财富的时候,由于使用了一些优良的HTML文件而让底部变得过大。有几点是亟需思忖的:

解析重视

举例HTML主文件要依靠多少个导入文本,而且导入文本中隐含相仿的库,当时会怎么样呢?比方,你要从导入文本中加载jQuery,如若每一种导入文本都含有加载jQuery的script标签,那么jQuery就会被加载三次,并且也会被实行三遍。

index.html

XHTML

<link rel="import" href="component1.html"> <link rel="import" href="component2.html">

1
2
<link rel="import" href="component1.html">
<link rel="import" href="component2.html">

component1.html

XHTML

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

1
<script src="js/jquery.js"></script>

component2.html

XHTML

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

1
<script src="js/jquery.js"></script>

HTML导入自动帮您消除了这几个主题材料。

与加载两回script标签的做法各异,HTML 导入对曾经加载过的HTML文件不再举行加载和推行。此前边的代码为例,通过将加载jQuery的script标签打包成二个HTML导入文本,那样jQuery就只被加载和实践贰回了。

但那还应该有一个难题:我们扩展了一个要加载的文书。怎么管理数据膨胀的文本呢?幸运的是,大家有贰个叫vulcanize的工具来缓慢解决那几个难点。

集结网络须要

Vulcanize 能将八个HTML文件合併成多个文书,进而收缩了互连网连接数。你能够依靠npm安装它,並且用命令行来使用它。你只怕也在用 grunt和gulp 托管有个别职分,那样的话你能够把vulcanize作为创设进度的一片段。

为了拆解解析正视以至联合index.html中的导入文本,使用如下命令:

JavaScript

$ vulcanize -o vulcanized.html index.html

1
$ vulcanize -o vulcanized.html index.html

透过进行那个命令,index.html中的重视会被剖析,况且会产生一个合併的HTML文件,称作 vulcanized.html。学习更加多关于vulcanize的文化,请看这儿。

在乎:http2的服务器推送功用被思量用于今后解除文件的连结与统风姿罗曼蒂克。

把Template、Shadow DOM、自定义成分跟HTML导入结合起来

让大家对那个文章连串的代码应用HTML导入。你后边只怕未有看过那几个作品,小编先解释一下:Template可以令你用证明的点子定义你的自定义成分的内容。Shadow DOM可以让多个要素的style、ID、class只据守到其自己。自定义成分得以让你自定义HTML标签。通过把那一个跟HTML导入结合起来,你自定义的web 组件会变得模块化,具备复用性。任什么人加多贰个Link标签就能够使用它。

x-component.html

XHTML

<template id="template"> <style> ... </style> <div id="container"> <img src="; <content select="h1"></content> </div> </template> <script> // This element will be registered to index.html // Because `document` here means the one in index.html var XComponent = document.registerElement('x-component', { prototype: Object.create(HTMLElement.prototype, { createdCallback: { value: function() { var root = this.createShadowRoot(); var template = document.querySelector('#template'); var clone = document.importNode(template.content, true); root.appendChild(clone); } } }) }); </script>

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<template id="template">
  <style>
    ...
  </style>
  <div id="container">
    <img src="http://webcomponents.org/img/logo.svg">
    <content select="h1"></content>
  </div>
</template>
<script>
  // This element will be registered to index.html
  // Because `document` here means the one in index.html
  var XComponent = document.registerElement('x-component', {
    prototype: Object.create(HTMLElement.prototype, {
      createdCallback: {
        value: function() {
          var root = this.createShadowRoot();
          var template = document.querySelector('#template');
          var clone = document.importNode(template.content, true);
          root.appendChild(clone);
        }
      }
    })
  });
</script>

index.html

XHTML

... <link rel="import" href="x-component.html"> </head> <body> <x-component> <h1>This is Custom Element</h1> </x-component> ...

1
2
3
4
5
6
7
8
...
  <link rel="import" href="x-component.html">
</head>
<body>
  <x-component>
    <h1>This is Custom Element</h1>
  </x-component>
  ...

只顾,因为x-component.html 中的document 对象跟index.html的相通,你没须要再写一些老祸患的代码,它会自动为你注册。

扶助的浏览器

Chrome 和 Opera提供对HTML导入的支撑,Firefox要在二零一四年7月后才支撑(Mozilla表示Firefox不陈设在近年提供对HTML导入的支持,声称供给首先通晓ES6的模块是什么达成的卡塔尔。

您能够去chromestatus.com或caniuse.com询问浏览器是不是援救HTML导入。想要在任何浏览器上应用HTML导入,能够用webcomponents.js(原名platform.js)。

相关财富

HTML导入就介绍这么多了。假如您想学越多关于HTML导入的文化,请前往:

  • HTML Imports: #include for the web – HTML5Rocks
  • HTML Imports spec

    赞 1 收藏 评论

至于我:XfLoops

金沙澳门唯一官网 1

腾讯网天涯论坛:@XfLoops 个人主页 · 我的小说 · 10

金沙澳门唯一官网 2

TAG标签:
版权声明:本文由金沙澳门唯一官网发布于前端开发,转载请注明出处:金沙澳门唯一官网:简单介绍HTML5中的文件导入