这期内容当中小编将会给大家带来有关jQuery中怎么实现跨域提交表单数据,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
成都创新互联是一家集网站建设,威海企业网站建设,威海品牌网站建设,网站定制,威海网站建设报价,网络营销,网络优化,威海网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。在本例中,为了演示跨域提交数据,我们假设A网站域名为www.xuebuyuan.com,B网站域名为demo.xuebuyuan.com。我们在A网站创建一个简单的表单,用于提交用户信息。
<form id="myform" action="#" method="post">
<p><label>姓名:</label><input type="text" class="input" name="username" /></p>
<p><label>性别:</label><input type="radio" name="sex" value="1" checked="checked" /> 男生
<input type="radio" name="sex" value="2" /> 女生 </p>
<p><label>年龄:</label><input type="text" class="input" name="age" /></p>
<p><input type="submit" class="btn" value="提 交" /></p>
</form>
当用户填写完毕表单并点击“提交”按钮时,使用jQuery获取表单信息,并通过getJSON提交给B网站,请看代码:
$(function(){
$("#myform").submit(function(){
var data = $(this).serialize(); //序列化表单数据
$.getJSON("http://demo.xuebuyuan.com/jsonp.php?callback=?",data,function(json){
var msg = '';
if(json){
var sex = json.sex==1? "男生":"女生";
msg = "<p id='result'><strong>提交成功!</strong><br/>姓名:
"+json.username+"<br/>性别:"+sex+"<br/>年龄:"+json.age+"</p>"
}else{
msg = "服务器忙,请稍候再试!";
}
$("#myform").after(msg); //将返回信息插入页面对应的元素后
});
return false;
});
});
从代码中可以看出,首先将表单数据序列化,获得json格式的表单数据,然后通过getJSON将数据发送给B网站URL:http://demo.xuebuyuan.com/jsonp.php?callback=?,注意URL后面有个callback=?,将请求转换为一个JSONP请求。然后根据B网站处理结果响应,并将响应结果动态显示在A网站的表单提交页面。
本例中,B网站的jsonp.php程序获取A网站提交过来的表单数据,并将数据进行必要的处理(如有需要,可将数据过滤并插入数据库中),然后返回JSON格式的数据给A网站的表单提交页面。
$result['username'] = $_GET['username'];
$result['sex'] = $_GET['sex'];
$result['age'] = $_GET['age'];
echo $_GET['callback'].'('.json_encode($result).')';
如果处理成功,会返回这样一串字符串:jsonp1331385001001({"username":"u5929u70edu7279","sex":"1","age":"28"})。
上述就是小编为大家分享的jQuery中怎么实现跨域提交表单数据了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注创新互联行业资讯频道。
本文标题:jQuery中怎么实现跨域提交表单数据-创新互联
分享地址:https://www.cdcxhl.com/article32/dchdpc.html
成都网站建设公司_创新互联,为您提供微信小程序、定制网站、虚拟主机、全网营销推广、网站排名、网站设计
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联