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