ajax返回javascript给页面执行

本文介绍了一种利用eval函数处理HTTP请求返回结果的方法,通过提取并执行纯JavaScript语句来简化页面上alert消息的展示过程,同时演示了如何分离脚本和其他内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值