当前位置:  开发笔记 > 编程语言 > 正文

调用从Ajax响应返回的JavaScript函数

如何解决《调用从Ajax响应返回的JavaScript函数》经验,为你挑选了5个好方法。

我有一个系统,我发送一个Ajax命令,它返回一个带有函数的脚本块.在DIV中正确插入此数据后,我希望能够调用此函数来执行所需的操作.

这可能吗?



1> Federico Zan..:

我想在这种形式下正确地解释你的问题:"好的,我已经完成了所有Ajax的工作;我只是想知道我的Ajax回调插入到DIV中的JavaScript函数是否可以在此时随时调用,也就是说,我不想在上下文中调用它来回调".

好的,如果您的意思是这样的答案是肯定的,那么您可以在浏览器中的页面持久性期间随时调用您的新代码,条件如下:

1)Ajax回调返回的JavaScript代码必须在语法上正常;
2)即使您的函数声明被插入到

我没有使用Ajax,但概念是一样的(即使我选择的例子肯定不是很聪明:-)

一般来说,我不会质疑你的解决方案设计,即它是否适合外部化+在单独的.js文件中泛化函数等,但请注意这样的解决方案可能引发进一步的问题,特别是如果您的Ajax调用应该重复,即如果相同函数的上下文应该更改,或者如果应该关注声明的函数持久性,那么您可能应该认真考虑将您的设计更改为此线程中的建议示例之一.

最后,如果我误解了你的问题,并且你在谈论Ajax回调返回时函数的上下文调用,那么我的感觉是建议krosenvold描述的Prototype方法,因为它是跨浏览器,经过测试并且功能齐全,这可以为您提供更好的未来实施路线图.



2> 小智..:

注意:eval()很容易被滥用,假设请求被第三方拦截并向您发送不受信任的代码.然后使用eval()运行这个不受信任的代码.请参阅此处了解eval()的危险性.


在返回的HTML/Ajax/JavaScript文件中,您将拥有一个JavaScript标记.给它一个ID,比如脚本.向这些标记添加id并不常见,但需要特别引用它.


在主窗口中,然后通过仅评估新的JavaScript代码块(在本例中,它称为runscript)来调用eval函数:

eval(document.getElementById("runscript").innerHTML);

它起作用,至少在Internet Explorer 9和Google Chrome中是有效的.


实施此解决方案有任何安全漏洞吗?

3> krosenvold..:

它是完全可能的,甚至还有一些相当合理的用例.使用Prototype框架,它完成如下.

new Ajax.Updater('items', '/items.url', {
    parameters: { evalJS: true}
});

请参阅Ajax更新程序的文档.选项位于常用选项集中.像往常一样,关于"这个"指向的地方有一些警告,所以阅读细则.

JavaScript代码将在加载时进行评估.如果内容包含功能,myFunc(), 您可以在myFunc()事后说出来.也许如下.

if (window["myFunc"])
   myFunc()

这将检查函数是否存在.也许某人有更好的跨浏览器方式,可以在Internet Explorer 6中运行.



4> DanSingerman..:

这似乎是一个相当奇怪的代码设计 - 通常直接从.js文件调用函数,然后只使用Ajax调用检索数据更有意义.

但是,我相信它应该通过在响应上调用eval()来工作- 只要它是语法正确的JavaScript代码.



5> kgiannakakis..:

使用jQuery,我会使用getScript

推荐阅读
重庆制造漫画社
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有