我们在使用代码编程一个网站的时候,通常情况下头部和尾部是相同的,如果一个网站的每个页面都把这些代码写一遍,不仅浪费时间,还显得重复代码很多
所以此时
把重复的页面单独摘出来
,在用到的时候从
外部直接引进去
,就能节省很多时间,减少很多代码。
在这里,有好
几种引入html文件的方式
,不过每种都是有利有弊,需要根据需要自行选择
有些人反馈解决了有些浏览器本地实现不了的问题:放到服务器上面!(感谢!!!)
<style type="text/css">
margin: 0;
padding: 0;
</style>
⚠️注意: 引入后主页面的CSS样式不适用于被引入页面。比如: 在主页面设置只在本页面生效,引入文件整体适用,但引入文件内容不适用。
import引入
<head>
中引入文件,<script>
中加载内容
href 链接引入的 html 文件,id 可以看做页面引导,在 script 中用到
<meta charset="utf-8" />
<title>主页面</title>
<link rel="import" href="top.html" id="page1"/>
<link rel="import" href="fotter.html" id="page2"/>
</head>
<script type="text/javascript">
document.write(page1.import.body.innerHTML);
</script>
你好呀!
<script type="text/javascript">
document.write(page2.import.body.innerHTML);
</script>
最后的运行效果:
为了客观反应不同方式的引入差距,下面是浏览器代码界面:
由上图可以看出,import引入除开script标签,在其他html body中写入什么就引入什么,完全的内容格式
<div class="top"></div>
<div class="center">
<p>你好,我在中间!</p>
</div>
<div class="footer"></div>
<script src="js/jq/jquery-3.2.1.min.js"></script>
<script type="text/javascript">
$(document).ready(function () {
$('.top').load('top.html');
$('.footer').load('fotter.html');
</script>
使用js引入,相当于把引入的 html
中 head
和 body
标签中的数据拖出来,在外面包了一个你自己写的标签,比如说上面代码中的 <div class="top"></div>
运行结果同import相同,这里不再展示
⚠️注意: head和body标签中的数据,不带标签,下图是浏览器显示代码
include 引入
涉及到一个从网上扒的封装函数,下面有(head和body标签中的数据直接引入)
<script src="js/include.js"></script>
<include src="top.html"></include>
<include src="center.html"></include>
<div id="">
<p>你没有看错,我在这!</p>
</div>
<include src="fotter.html"></include>
</body>
浏览器代码分析
include.js压缩代码:
(function(window,document,undefined){var Include39485748323=function(){};Include39485748323.prototype={forEach:function(array,callback){var size=array.length;for(var i=size-1;i>=0;i-=1){callback.apply(array[i],[i])}},getFilePath:function(){var curWwwPath=window.document.location.href;var pathName=window.document.location.pathname;var localhostPaht=curWwwPath.substring(0,curWwwPath.indexOf(pathName));var projectName=pathName.substring(0,pathName.substr(1).lastIndexOf('/')+1);return localhostPaht+projectName},getFileContent:function(url){var ie=navigator.userAgent.indexOf('MSIE')>0;var o=ie?new ActiveXObject('Microsoft.XMLHTTP'):new XMLHttpRequest();o.open('get',url,false);o.send(null);return o.responseText},parseNode:function(content){var objE=document.createElement("div");objE.innerHTML=content;return objE.childNodes},executeScript:function(content){var mac=/<script>([\s\S]*?)<\/script>/g;var r="";while(r=mac.exec(content)){eval(r[1])}},getHtml:function(content){var mac=/<script>([\s\S]*?)<\/script>/g;content.replace(mac,"");return content},getPrevCount:function(src){var mac=/\.\.\//g;var count=0;while(mac.exec(src)){count+=1}return count},getRequestUrl:function(filePath,src){if(/http:\/\//g.test(src)){return src}var prevCount=this.getPrevCount(src);while(prevCount--){filePath=filePath.substring(0,filePath.substr(1).lastIndexOf('/')+1)}return filePath+"/"+src.replace(/\.\.\//g,"")},replaceIncludeElements:function(){var $this=this;var filePath=$this.getFilePath();var includeTals=document.getElementsByTagName("include");this.forEach(includeTals,function(){var src=this.getAttribute("src");var content=$this.getFileContent($this.getRequestUrl(filePath,src));var parent=this.parentNode;var includeNodes=$this.parseNode($this.getHtml(content));var size=includeNodes.length;for(var i=0;i<size;i+=1){parent.insertBefore(includeNodes[0],this)}$this.executeScript(content);parent.removeChild(this);})}};window.onload=function(){new Include39485748323().replaceIncludeElements()}})(window,document);
object引入和iframe引入
带有滚动条,视情况使用
<object style="border:1px solid red" type="text/x-scriptlet"
data="top.html" width="100%" height="200px"></object>
<iframe marginwidth=0 marginheight=0 width="100%" height=200
src="top.html" frameborder="no" <!--scrolling="no"-->></iframe>
两中引入方式比较
默认高度为150
引入后本页面html嵌套引入页面html,整个引入