ajax中如何实现innerHTML中javascript的运行

ajax|javascript

在参考前人的一些做法后,采用了一些变通方式,和添加一些额外标记,来较好的实现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" >
<input type="button" value="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的时候就可能用到)

下面的例子中有具体的应用:一个基于ajax的,个性网页构建雏形

http://bbs.nju.edu.cn/file/Y/ycg/obj.rar

 

 

时间: 2024-08-31 13:22:02

ajax中如何实现innerHTML中javascript的运行的相关文章

让插入到 innerHTML 中的 script 跑起来的代码第1/2页_javascript技巧

在做 ajax 编程时,我们常常需要将 xmlhttp 获取到的页面内容通过 innerHTML 来赋给某个容器(比如 div.span 或者 td 等),但是这里存在一个问题,就是我们将要赋给 innerHTML 的页面内容如果包含有脚本程序,这些脚本程序不管是外部脚本,还是内部脚本,可能(1)都不会被执行.这个问题在某些时候微不足道,甚至可以忽略,但有些时候,这个问题就非常严重,它很可能让我们的程序得不到预期的结果.因此我们需要解决这个问题. 如果你读过 MSDN,你会发现并非所有插入到 i

让插入到 innerHTML 中的 script 跑起来的实现代码_javascript技巧

这个问题在某些时候微不足道,甚至可以忽略,但有些时候,这个问题就非常严重,它很可能让我们的程序得不到预期的结果.因此我们需要解决这个问题. 如果你读过 MSDN,你会发现并非所有插入到 innerHTML 中的脚本都不能执行,如果这段脚本的 script 标签中包含了 defer 属性,IE 会正确的执行这些脚本程序.但不幸的是,Moziila/Firefox 和 Opera 可不吃这一套,不管 script 标签有没有设置 defer 属性,这些浏览器都不会向 IE 那样去执行插入到 inne

javascript中innerText和innerHTML属性用法实例分析

  本文实例讲述了javascript中innerText和innerHTML属性用法.分享给大家供大家参考.具体分析如下: 几乎所有DOM元素都有innerText,innertHTML属性(注意大小写),分别是元素标签内 的文本表示形式和HTML源代码,这两个属性是可读可写的 innerHTML也可以取代createElement,属于简单,粗放型,后果自负的创建 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24

javascript中innerText和innerHTML属性用法实例分析_javascript技巧

本文实例讲述了javascript中innerText和innerHTML属性用法.分享给大家供大家参考.具体分析如下: 几乎所有DOM元素都有innerText,innertHTML属性(注意大小写),分别是元素标签内 的文本表示形式和HTML源代码,这两个属性是可读可写的 innerHTML也可以取代createElement,属于简单,粗放型,后果自负的创建 <html xmlns="http://www.w3.org/1999/xhtml"> <head>

如何通过ajax访问aspx的CodeBehind中的方法

在项目中突然看到,aspx中的ajax可以访问aspx.cs中的方法,觉得很新奇,也许是lz少见多怪,不过,真的有发现新大陆似的那种兴奋,你也许知道这代表什么,学会了这种方式,代表你以后,可以建更少的页面,更少ashx,更少的.....能不兴奋吗?在lz的印象中,ajax一般都和一般处理程序联系起来的,请求另外的aspx页面就不说了,而请求自身CodeBehind中的方法真的很少见,这里记录一下,也许也有跟我一样不知道的朋友,希望能帮到你.只是知道ajax可以访问webservice中加webm

IE6-IE9中tbody的innerHTML不能赋值的解决方法

 IE6-IE9中tbody的innerHTML不能赋值,重现代码如下 Js代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 <!DOCTYPE html>  <html>  <head>  <meta charset="utf-8"/>  <title>IE6-IE9中tbody的innerHTM

innerHTML中标签可以换行的方法汇总_javascript技巧

在用innerHTML生成结构时,为了看起来结构明快,可以在每行的末尾加一个反斜线\,即可保持html原结构,而不至于将标签都挤在一块 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>innerHTML中标签可以换行的方法</title> </head> <body> <sc

在页面中输出当前客户端时间javascript实例代码_javascript技巧

时间对象(Date())比较简单,本文旨在为初学者入门使用,大牛可略过! 本文承接基础知识实例,说一下实例的要求: 在页面中输出当前客户端时间(2015年1月1日星期一10:10:10这样的格式),每过一秒中页面不刷新,但是时间自动更新(用两种定时器方法都可以实现),鼠标点击时间,如果原先运动则停止,如果停止则继续运动: 要求基本上可分为2部分:一是不刷新自动更新时间,二是点击时间停止或更新时间 好,那我们还是老规矩,一步一步来,既然是时间,那就会用到时间对象 new Date(); var n

asp.net中ajax技术是否可以实现停止服务器端正在运行的按钮事件

问题描述 asp.net中ajax技术是否可以实现停止服务器端正在运行的按钮事件 给予B/S的webform项目 在服务器端有一个按钮事件 执行时间较长 所以就添加了一个按钮用来可以随时停止正在运行的耗时较长的按钮 问题是那个正在服务器端运行的按钮是否可以被其他按钮终止呢?求解答 解决方案 不可以.首先将长时间操作的任务放在按钮事件中就是错误的.按钮事件在页面回传前调用,ajax回发根本在页面加载后.你应该用消息队列.后台服务去执行长时间的任务. 解决方案二: 这个理论上是可以实现的. 服务器端