Welcome to the website navigation,本站只接受合法正规的企业网站,欢迎站长们提交你的网站获得展示和流量有任何问题请联系站长,欢迎大家加入本站。

                
提交网站
  • 网站:76083
  • 待审:5
  • APP:577
  • 文章:304411
  • 会员:56004
文字内链包年1000元 文字内链包年1000元 文字内链包年1000元 AI办公网站 AI绘画工具 AIchat

名站网址导航名站网址导航小编为爱好网页hTML5的朋友提供关于网页hTML5的相关知识。

  • 本篇文章的具体介绍如下

Template、Shadow DOM及Custom Elements 让您创见UI组件比以前更容易了。但是像网页hTML、CSS、JavaScript这样的资源仍然需要一个个地去加载,这是很没效率的。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

删除重复依赖也并不简单。例如,现在加载jQuery UI或Bootstrap就需要为JavaScript、CSS及Web Fonts添加单独的网页文章标签。如果您的Web 组件应用了多重的依赖,那事情就变得更为复杂。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

网页hTML 导入让您以一个合并的网页hTML相关站点文件来加载这些资源。
使用网页hTML导入OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

为加载一个网页hTML相关站点文件,您需要增加一个link网页文章标签,其rel属性为import,herf属性是网页hTML相关站点文件的路径。例如,如果您想把component.html加载到index.html:OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

index.html
 
OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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导入相关站点文件。)添加任何的资源,包括脚本、样式表及字体,就跟往普通的网页hTML添加资源一样。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

component.html
 
OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

XML/网页hTML Code 复制内容到剪贴板
  1. <link rel="stylesheet" href="css/style.css">  
  2. <script src="js/script.js"></script>  

doctype、html、 head、 body这些网页文章标签是不需要的。网页hTML 导入会立即加载要导入的文档,解析文档中的资源,如果有脚本的话也会立即执行它们。
执行顺序OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

浏览器解析网页hTML文档的方式是线性的,这就是说网页hTML顶部的script会比底部先执行。并且,浏览器通常会等到JavaScript具体代码执行完毕后,才会接着解析后面的具体代码。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

为了不让script 妨碍网页hTML的渲染,您可以在网页文章标签中添加async或defer属性(或者您也可以将script 网页文章标签放到页面的底部)。defer 属性会延迟脚本的执行,直到全部页面解析完毕。async 属性让浏览器异步地执行脚本,从而不会妨碍网页hTML的渲染。那么,网页hTML 导入是怎样工作的呢?OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

网页hTML导入相关站点文件中的脚本就跟含有defer属性一样。例如在下面的示例中,index.html会先执行script1.js和script2.js ,然后再执行script3.js。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

index.html
 
OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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
 
OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

XML/网页hTML Code 复制内容到剪贴板
  1. <script src="js/script1.js"></script>     // 2.   
  2. <script src="js/script2.js"></script>     // 3.  

1.在index.html 中加载component.html并等待执行OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

2.执行component.html中的script1.jsOrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

3.执行完script1.js后执行component.html中的script2.jsOrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

4.执行完 script2.js继而执行index.html中的script3.jsOrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

注意,如果给link[rel="import"]添加async属性,网页hTML导入会把它当做含有async属性的脚本来对待。它不会等待网页hTML导入相关站点文件的执行和加载,这意味着网页hTML 导入不会妨碍网页hTML主相关站点文件的渲染。这也给提升网站性能带来了可能,除非有其他的脚本依赖于网页hTML导入相关站点文件的执行。
跨域导入OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

从根本上说,网页hTML导入是不能从其他的域名导入资源的。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

比如,您不能从http://webcomponents.org/向 http://example.com/ 导入网页hTML 相关站点文件。为了绕过这个限制,可以使用CORS(跨域资源共享)。想了解CORS,请看这篇文章。
网页hTML导入相关站点文件中的window和document对象OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

前面我提过在导入网页hTML相关站点文件的时候里面的脚本是会被执行的,但这并不意味着网页hTML导入相关站点文件中的网页文章标签也会被浏览器渲染。您需要写一些JavaScript具体代码来帮忙。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

当在网页hTML导入相关站点文件中使用JavaScript时,有一点要提防的是,网页hTML导入相关站点文件中的document对象实际上指的是网页hTML主相关站点文件中的document对象。以前面的具体代码为例,index.html和  component.html 的document都是指index.html的document对象。怎么才能使用网页hTML导入相关站点文件中的document 呢?借助link中的import 属性。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

index.html
 
OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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.OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

component.html
 
OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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属性,因为并不是所有的浏览器都支持这个属性。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

component.htmlOrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 
OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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;
性能方面的考虑OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

使用网页hTML 导入的一个好处是能够将资源组织起来,但是也意味着在加载这些资源的时候,由于使用了一些额外的网页hTML相关站点文件而让头部变得过大。有几点是需要考虑的:
解析依赖OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

假如网页hTML主相关站点文件要依赖多个导入相关站点文件,而且导入相关站点文件中含有相同的库,这时会怎样呢?例如,您要从导入相关站点文件中加载jQuery,如果每个导入相关站点文件都含有加载jQuery的script网页文章标签,那么jQuery就会被加载两次,并且也会被执行两次。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

index.html
 
OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

XML/网页hTML Code 复制内容到剪贴板
  1. <link rel="import" href="component1.html">  
  2. <link rel="import" href="component2.html">  

component1.html
 
OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

XML/网页hTML Code 复制内容到剪贴板
  1. <script src="js/jquery.js"></script>  

component2.html
 
网页hTML导入自动帮您解决了这个问题。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

与加载两次script网页文章标签的做法不同,网页hTML 导入对已经加载过的网页hTML相关站点文件不再进行加载和执行。以前面的具体代码为例,通过将加载jQuery的script网页文章标签打包成一个网页hTML导入相关站点文件,这样jQuery就只被加载和执行一次了。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

但这还有一个问题:咱们增加了一个要加载的相关站点文件。怎么处理数目膨胀的相关站点文件呢?幸运的是,咱们有一个叫vulcanize的工具来解决这个问题。
合并网络请求OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

Vulcanize 能将多个网页hTML相关站点文件合并成一个相关站点文件,从而减少了网络连接数。您可以借助npm安装它,并且用命令行来使用它。您可能也在用 grunt和gulp 托管一些任务,这样的话您可以把vulcanize作为构建过程的一部分。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

为了解析依赖以及合并index.html中的导入相关站点文件,使用如下命令:


OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

复制具体代码 具体代码如下: $ vulcanize -o vulcanized.html index.html

OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

通过执行这个命令,index.html中的依赖会被解析,并且会产生一个合并的网页hTML相关站点文件,称作 vulcanized.html。学习更多有关vulcanize的知识,请看这儿。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

注意:http2的服务器推送功能被考虑用于以后消除相关站点文件的连结与合并。
把Template、Shadow DOM、自定义网页元素跟网页hTML导入结合起来OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

让咱们对这个文章系列的具体代码使用网页hTML导入。您之前可能没有看过这些文章,我先解释一下:Template可以让您用声明的方式定义您的自定义网页元素的内容。Shadow DOM可以让一个网页元素的style、ID、class只作用到其本身。自定义网页元素可以让您自定义网页hTML网页文章标签。通过把这些跟网页hTML导入结合起来,您自定义的web 组件会变得模块化,具有复用性。任何人添加一个Link网页文章标签就可以使用它。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

x-component.htmlOrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 
OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

XML/网页hTML Code 复制内容到剪贴板
  1. <template id="template">  
  2.   <style>  
  3.     ...   
  4.   </style>  
  5.   <div id="container">  
  6.     <img src="http://webcomponents.org/img/logo.svg">  
  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
 
OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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的一样,您没必要再写一些棘手的具体代码,它会自动为您注册。
支持的浏览器OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

Chrome 和 Opera提供对网页hTML导入的支持,Firefox要在2014年12月后才支持(Mozilla表示Firefox不计划在近期提供对网页hTML导入的支持,声称需要首先了解ES6的模块是怎样实现的)。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

您可以去chromestatus.com或caniuse.com查询浏览器是否支持网页hTML导入。想要在其他浏览器上使用网页hTML导入,可以用webcomponents.js(原名platform.js)。
相关资源OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

网页hTML导入就介绍这么多了。如果您想学更多关于网页hTML导入的知识,请前往:OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

    网页hTML Imports: #include for the web – 网页hTML5教程Rocks
    网页hTML Imports specOrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

检测浏览器对网页hTML5教程和CSS3支持度的实用具体的方法OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

而 Modernizr 就可以帮助您完成对浏览器所支持 网页hTML5教程 特性的检查。OrnAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

关于网页hTML5的相关知识就说到这里希望可以帮助朋友们。,网页hTML5

标签:HTML5

分享到:

  admin

注册时间:

网站:0 个   APP:3 个  文章:0 篇

  • 76083

    网站

  • 577

    APP

  • 304411

    文章

  • 56004

    会员

赶快注册账号,推广您的网站吧!
文章分类
热门网站
最新入驻APP小程序

宝贝市场2023-02-08

宝贝市场——买手和卖家商品展示

夺宝助手2023-02-08

夺宝助手小程序,查看每日快夺宝平

查诚信2023-02-08

查诚信是一款免费的商业查询工具

车价天天报2023-02-08

快速连接汽车销售,获知汽车最新报

考勤助理小程序2023-02-08

上班签到考勤,实时定位,后台轻松

汽车报价大全查询2023-02-08

汽车报价大全查询提供最新汽车市