A JavaScript Fancier

伟大的javascript技术研究中...

  IT博客 :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  304 随笔 :: 0 文章 :: 479 评论 :: 0 Trackbacks


首先声明,本文非我原作,在一blog看到此文,然后结合一网友回复整理此文.

用法:
include_js(src,[reload]);
src: js文件的路径名
reload:可选参数,0或1,表示是否重复加载同一个url的js文件。
用途:
本函数可以用于一些广告和统计的js文件异步加载,避免了因加载js文件而造成的网页显示速度慢的问题。

将此函数修改一下便可以动态加载css文件,不过用处就没有加载js文件的大。
function include_js(path,reload) 

      
var scripts = document.getElementsByTagName("script"); 
      
if (!reload) 
      
for (var i=0;i<scripts.length;i++
            
if (scripts[i].src && scripts[i].src.toLowerCase() == path.toLowerCase() ) return
      
var sobj = document.createElement('script'); 
      sobj.type 
= "text/javascript"
      sobj.src 
= path; 
      
var headobj = document.getElementsByTagName('head')[0]; 
      headobj.appendChild(sobj); 
}

但是这样当加载的js文件含有document.write语句时,在IE下没有反应,但在Mozilla Firefox 下就会让你原来的网页消失,只显示document.write出来的内容.对此问题一网友给出了一种比较好的解决办法,当然是重写document.write方法.下面网友原做内容:
有一个可以让document.write信息显示出来的方法:
先在网页中需要显示write出来的内容的地方加入一个div标签:
<div id='jsdiv'></div>
然后在include_js之前加上这句:
document.write = function (s)
{
  document.getElementById('jsdiv').innerHTML+=s;
  return false;
}
这样不仅可以不让document.write方法破坏网页,也避免了write出来的信息丢失的痛苦。

偶测试了下果然好用.嘿嘿

posted on 2006-07-03 09:40 Yemoo'S JS Blog 阅读(1197) 评论(0)  编辑 收藏 引用 所属分类: javascript代码收藏
只有注册用户登录后才能发表评论。