网络编程 
首页 > 网络编程 > 浏览文章

ajax跨域(基础域名相同)表单提交的方法

(编辑:jimmy 日期: 2024/11/15 浏览:3 次 )

本文实例讲述了ajax跨域(基础域名相同)表单提交的方法。分享给大家供大家参考。具体如下:

1.要在做ajax提交的页面中添加如下js语句:

<script type="text/javascript"> 
  document.domain="基础域名"; 
</script> 

2.ajax表单提交表单时可以使用一个jquery的一个表单插件jquery.form.js

使用语法如下:

//fromPost为要收集数据的form表单的id  
$("#formPost").ajaxSubmit({ 
  url:"跨域的业务处理地址", 
  cache:false, 
  dataType:"html", 
  iframe:true, 
  success:function (data){ 
 //返回如果是json可以这样处理一下,xml格式需要做其它的处理
 eval("data="+data); 
   if(data.flag == 'OK'){ 
   }
});

3.跨域的业务处理的返回值中必需含有以下语句

<script type="text/javascript">
  document.domain="基础域名";
</script>

4.剩下的返回值可以是json,xml格式或其它自定义的格式,只要客户端能够解析出想要结果就可以

5.这样在做ajax提交的页面中就可以取到表单跨域提交后的返回值了,取到返回值后就可以接着做其它的处理了

说明:

1.基础域名:两个及两个以上域名的公有部分,公有部分至少要包含二级域名或二级域名之上的部分

2.document.domain="基础域名"; //这句话是为了使域名相同,解除跨域的限制,详见:《js设置document.domain实现跨域的注意点分析》

3.关于跨域提交还有很多其它的解决办法,如:《js同源策略详解》

希望本文所述对大家的javascript程序设计有所帮助。

上一篇:AJAX提交表单数据实例分析
下一篇:Ajax加载外部页面弹出层效果实现方法