我们知道AJAX用于从服务器请求HTML格式的Web部件。是否可以使用AJAX请求包含函数的脚本?
答案 0 :(得分:1)
是的,你可以通过ajax
加载javascripthttp://api.jquery.com/jQuery.getScript/
$.getScript("ajax/test.js")
.done(function(script, textStatus) {
console.log( textStatus );
})
.fail(function(jqxhr, settings, exception) {
$( "div.log" ).text( "Triggered ajaxError handler." );
});
你也可以尝试(how to run javascript in html loaded via ajax)中提到的这样的事情:
require("extra.js", function () {
functionDefinedInExtraJS();
});
//Sample require function:
function require(file, callback) {
var script = document.getElementsByTagName('script')[0],
newjs = document.createElement('script');
// IE
newjs.onreadystatechange = function () {
if (newjs.readyState === 'loaded' || newjs.readyState === 'complete') {
callback();
}
};
// others
newjs.onload = function () {
callback();
};
newjs.src = file;
script.parentNode.insertBefore(newjs, script);
}
另一种方法是使用eval()函数并将字符串回复转换为可用的javascript代码。
答案 1 :(得分:1)
以下是如何使用eval()来完成所需内容的示例:
var xmlhttp;
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
eval(xmlhttp.responseText);
// you can use whatever functionw as returned from the server from this line on :)
}
}
xmlhttp.open("GET","your-server-page-url",true);
xmlhttp.send();
答案 2 :(得分:0)
是否可以使用AJAX请求包含函数的脚本?
是的,有可能。这些功能可以在客户端上执行。例如,使用jQuery,您甚至可以使用一个允许您执行此类请求的函数:$.getScript
。