现在的位置: 首页 > 综合 > 正文

实现页面无缝加载

2018年01月28日 ⁄ 综合 ⁄ 共 1461字 ⁄ 字号 评论关闭

在页面加载性能当中,页面被阻塞是影响页面主要内容(包括图片等)及时呈现在用户面前的一个重要因素之一,所以我们需要在页面中合理处置外调CSS及JS文件。

样式表下面如果有script标签则同样会阻塞后续页面内容的加载,但我们通常希望优先加载样式表,这样才不会看到裸奔的页面,所以我们只须关注script的无阻塞加载即可。

 

 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="
http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>页面阻塞测试</title>
<link rel="stylesheet" href="
http://www.ueder.net/wp-content/themes/DerStyle/style.css"
type="text/css" media="screen" />
<script type="text/javascript">
function loadScript(url, callback) {
 setTimeout(function(){
  //创建script
  var script = document.createElement("script");
  script.type = "text/javascript";
  script.src = url;
  document.getElementsByTagName("head")[0].appendChild(script);
  //加载完毕回调
  if(script.readyState) { //for IE
   script.onreadystatechange = function() {
    if(script.readyState == "loaded" || script.readyState == "complete") {
     script.onreadystatechange = null;
     if(callback){callback();}
    }
   };
  } else { //for Others
   script.onload = function() {
    if(callback){callback();}
   };
  }
 },0);
}
//加载script
loadScript("
http://www.ueder.net/testhtml/jquery/jquery.js");
loadScript("
http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.js");
</script>
</head>
<body>
<script type="text/javascript">
//这里随便执行的代码
var a;
</script>
以下内容将不会被阻塞
<div style=" height:100px; background:red;"></div>
<img src="
http://www.ueder.net/testhtml/picshow/datapic/0e0c883622903fb1a61e12be.jpg"
/>
</body>
</html>

抱歉!评论已关闭.