因为一个需求,查询后如果没有数据,则返回给用户一个alert。 而我又比较懒,不喜欢在页面写alert。而且这样还多写了很多代码。

经过多次试验,原来eval()函数正是我所要的。

javascript:   

var txt=http_request.responseText;
eval(txt);

action:

response.getWriter().write(" var a=1; var b=2; alert(a+b); tttt();");

这样既可执行脚本,也可以执行页面的某个方法tttt();

真是超级好用了,哈哈哈。


-------------------------------------------------------------------------------

给你说说原理吧
eval就是执行javascript语句字符串

你想要执行javascript语句字符串 那么你就想办法提取出单纯的语句,最好不待 <script>标记
它只执行语句
至于其他内容你不要放入eval,因为它只是执行并不会帮你把内容显示出来

至于如何分离,方法也有很多种
要么你直接在2.html不要写 <script>标记
要么你分离
string str1 = http.responseText.splite( <script>);
string str2 = str1[1].splite( </script>);
string str3 = str2[0];


---------------------------------------------------------------------------------------


//用正则表达式分离脚本和其他内容
function   addfriend(url) 

$(
"loading").style.display="block"
var   http=new   ajax(); 
http.onreadystatechange
=function   () 

if(ajax_returnresponse(http)) 

var resTexthttp.responseText;
var reg = /<script[^>]*>((.|\n)+)<\/script>/i;
var match=resText.match(reg);
var MyScript="";
if(match!=null//有脚本返回
{
 MyScript
=match[1];
 eval(MyScript);
//执行脚本
}
var Html=resText.replace(reg,"");//获取不包含脚本的其他内容
$("loading").innerHTML=Html; 
info(); 
return   false