Ajax 请求后将变量传递给回调

发布于 2024-09-17 21:30:38 字数 199 浏览 9 评论 0原文

除了打印结果之外,在执行 Ajax 请求(JS->PHP)后是否有更优雅的方式传递变量?

打印可能会变得有点混乱,并且在返回值方面也没有提供很大的灵活性(例如难以传递对象)。

另外,我在我的 Ajax 请求回调之一中打印了这个随机空间,但我无法弄清楚它来自哪里。通过传递序列化变量或类似的东西就不会存在这个问题,对吗?

提前致谢!

Is there a more elegant way of passing a variable after performing an Ajax request (JS->PHP) other than printing the results?

Printing can get a little messy and also doesn't offer a lot of flexibility in terms of the return value (e.g. hard to pass objects).

Also, I had this random space that was printed in one of my Ajax request callbacks and I could not figure out where it came from. This problem would not exist with passing serialized variables or something like that, right?

Thanks in advance!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

熟人话多 2024-09-24 21:30:38

以 {url:"",method:"",data:{...},callback:function(){}} 形式传递属性

在回调中你可以做很多事情,谷歌“javascriptclosures”。

希望这有帮助。

var ajax=function(){
  try{
    var xml       =new XMLHttpRequest();
    var args      =arguments;
    var context   =this;
    var multipart ="";

    xml.open(args[0].method,args[0].url,true);

    if(args[0].method.search(/post/i)!=-1){
      var boundary=Math.random().toString().substr(2);
      xml.setRequestHeader("content-type","multipart/form-data; charset=utf-8; boundary="+boundary);
      for(var key in args[0].data){
        multipart+="--"+boundary+"\r\ncontent-Disposition: form-data; name="+key+"\r\ncontent-type: application/octet-stream\r\n\r\n"+args[0].data[key]+"\r\n";
      }
      multipart+="--"+boundary+"--\r\n";
    }

    xml.onreadystatechange=function(){
      try{
        if(xml.readyState==4){
          context.txt=xml.responseText;
          context.xml=xml.responseXML;
          args[0].callback();
        }
      }
      catch(e){}
    }

    xml.send(multipart);
  }
  catch(e){}
}

如果你想得到响应,你可以使用这个:

var response={}; ajax.call(response,{...args...})

并且你可以通过response.txt或response.xml检索所有数据。

Pass attribute in form {url:"",method:"",data:{...},callback:function(){}}

In callback you can do a lot of stuff, google "javascript closures".

Hope this helps.

var ajax=function(){
  try{
    var xml       =new XMLHttpRequest();
    var args      =arguments;
    var context   =this;
    var multipart ="";

    xml.open(args[0].method,args[0].url,true);

    if(args[0].method.search(/post/i)!=-1){
      var boundary=Math.random().toString().substr(2);
      xml.setRequestHeader("content-type","multipart/form-data; charset=utf-8; boundary="+boundary);
      for(var key in args[0].data){
        multipart+="--"+boundary+"\r\ncontent-Disposition: form-data; name="+key+"\r\ncontent-type: application/octet-stream\r\n\r\n"+args[0].data[key]+"\r\n";
      }
      multipart+="--"+boundary+"--\r\n";
    }

    xml.onreadystatechange=function(){
      try{
        if(xml.readyState==4){
          context.txt=xml.responseText;
          context.xml=xml.responseXML;
          args[0].callback();
        }
      }
      catch(e){}
    }

    xml.send(multipart);
  }
  catch(e){}
}

If you want to get back response you can use this:

var response={}; ajax.call(response,{...args...})

and you can retrieve all data by response.txt or response.xml.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文