AJAX从服务器请求另一个javascript或函数

时间:2013-09-06 08:20:52

标签: javascript ajax

我们知道AJAX用于从服务器请求HTML格式的Web部件。是否可以使用AJAX请求包含函数的脚本?

3 个答案:

答案 0 :(得分:1)

是的,你可以通过ajax

加载javascript

http://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