IT技术精粹[JiShuBu.Com]-倾力打造一流IT技术平台!
  • 登录
  • 注册
  • 设为首页
  • 加入收藏
  • 网站首页
  • IT风向标
  • 网站优化
  • Html
  • CSS
  • JavaScript
  • ASP
  • Php/Mysql
  • Flash
  • Ajax
  • 源码下载
  • 精美桌面
  • 供求信息
  • 超稳定100M虚拟主机只要100元,还送50M邮箱!
  • 文字广告招商中...
  • 会员注册 | 用户登录 | 我要投稿
  • 信息订阅
实现innerHTML中javascript的运行,从而使的页面各个模块间更好的交互,和数据共享 您现在正在浏览:首页 > Ajax > 
实现innerHTML中javascript的运行,从而使的页面各个模块间更好的交互,和数据共享

作者: 发布时间:2008-01-19 16:20:40 来源:
在参考前人的一些做法后,采用了一些变通方式,和添加一些额外标记,来较好的实现innerHTML中javascript的运行,从而使的页面各个模块间更
好的交互,和数据共享.
先看下面的例子:
复制内容到剪贴板
代码:
<html>
<head>
</head>
<script>
var title = "hello";
var time = 0;
var author = "vickenyang";
var email = "ycg01@software.nju.edu.cn";
</script>
<body>
<div id="div_1">
<SPAN style="display: none">hidden</SPAN>
hehe
  <!--bs-->
  <script>
   document.write("first");
  </script>
  <!--es-->
  这是第一个页面!
  <br>
  <!--bs-->
  <script>
   time++;
   document.write(title+time+author);
   //alert(time);
   document.write("<br>---------------");
  </script>
  <!--es-->
  <input type="text" name="test" value="test">
</div>
<script>
function refreshDiv(div)
{
var html = "";
function changediv()
{
  var oldwrite = document.write;
  var oldwriteln = document.writeln;
  document.write = function(str)
  {
   html += str;
  }
  document.writeln = function (str)
  {
   html += str + "\n";
  }
  var htmlTmp = div.innerHTML;
  //ie默认大写,添加为支持firefox,美中不足,会替换所有script值,如果只是ie应用,可注销此行
  htmlTmp = htmlTmp.replace(/script/gi,"SCRIPT");
  //alert(htmlTmp);
  var pos_1 = 0;
  var pos_2 = 0;
  pos_1 = htmlTmp.indexOf("<SCRIPT>",pos_1);
  while(pos_1 != -1)
  {
   html += htmlTmp.substring(pos_2,pos_1);
   var pos_3 = htmlTmp.indexOf("</SCR"+"IPT>",pos_1);
   html += htmlTmp.substring(pos_1,pos_3+"<-SCRIPT>".length);
   pos_2 = pos_1+"<SCRIPT>".length;
   eval(htmlTmp.substring(pos_2,pos_3));
   pos_2 = htmlTmp.indexOf("<!--es-->",pos_3);
   pos_1 = htmlTmp.indexOf("<SCRIPT>",pos_1+1);
  }
  html += htmlTmp.substring(pos_2,htmlTmp.length);
  document.write = oldwrite;
  document.writeln = oldwriteln;
}
eval("changediv();");
div.innerHTML = html;
}
function change()
{
refreshDiv(document.getElementById('div_1'));
}
function change2()
{
document.write("over");
}
</script>
<input type="button" value="change" onclick="change();">
<input type="button" value="change2" onclick="change2();">
</body>
</html>
步骤:
1.在div的第一行加上<SPAN style="display: none">hidden</SPAN>(不这么做,ie会忽略首位的js)
2.在div中每一个js的前后加上<!--bs--><!--es-->标记.
原理:代码会告诉你的.如果你有更好的方法,请邮件联系,共同探讨.
补:
function refreshDiv(div)
{
var html = "";
如果在特殊的应用中用到递归调用,可以将此处的html 定义为全局变量,这样,保证递归刷新时候,显示的是最后一个页面.(如,你想在ajax中,异步load数据,在回调函数中指定刷新div的时候就可能用到)
  
【评论】【加入收藏夹】【大 中 小】【打印】【关闭】
※ 相关信息
无相关信息

发表评论
查看评论 
用户名: 密码:
验证码: 匿名发表
[注册帐号]
[控制面板]
[用户登陆]
[修改资料]
[用户收藏]
[我的状态]
[退出登陆]
 
文章搜索
     
    [添加文章]   [管理文章]
最新技术文档
    ·中国移动188号段将于1月8日起在深圳正式放号
    ·PHP与Javascript的两种交互方式
    ·使用wordpress中的函数 (PHP)
    ·js倒计时效果-精确到秒 (Javascript)
    ·PHP无刷新删除数据
    ·PHP文件系统处理类
    ·PHP文件缓存数据类
    ·PHPMailer邮件类利用smtp.163.com发送邮件方
    ·PHP的POST方式
    ·md5 结合 crypt =无敌密码
技术文档排行榜
    ·天气预报小偷,根据IP自动判断地址
    ·超经典计算机使用问题105答
    ·CSS网页布局入门教程:下拉及多级弹出式菜单
    ·'AjaxPro'未定义错误的原因&javascript顺
    ·[初学者必读]网页制作之HTML基础知识
    ·DIV&CSS打造自动伸展三栏复合布局
    ·近1000本javascript电子图书下载列表
    ·CSS 文字樣式技巧 (摘自一台湾网站,确实很
    ·阿里妈妈广告的投放技巧
    ·ajax+php无刷新二级联动下拉菜单(省市联动)
关于站点 - 广告服务 - 联系我们 - 免责声明 - 程序支持 - 网站地图 - 留言中心 - 返回顶部

Copyright © 2007-2008 www.Jishubu.com online services. All rights reserved. Template designed by laogui.
违法不良信息举报中心 津ICP备07002356号