因为一个需求,查询后如果没有数据,则返回给用户一个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;
}
}