成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用jQuery實現跨域提交表單數據

開發 前端
在jQuery中,我們使用json數據類型,通過getJSON方法來實現從服務端獲取或發送數據,而當要向不同遠程服務器端提交或者獲取數據時,要采用jsonp數據類型。

 

我們在WEB開發中有時會遇到這種情況,比如要從A網站收集用戶信息,提交給B網站處理,這個時候就會涉及到跨域提交數據的問題。本文將給您介紹如何使用jQuery來實現異步跨域提交表單數據。

[[78308]]

在jQuery中,我們使用json數據類型,通過getJSON方法來實現從服務端獲取或發送數據,而當要向不同遠程服務器端提交或者獲取數據時,要采用jsonp數據類型。使用這種類型的話,會創建一個查詢字符串參數 callback=? ,這個參數會加在請求的URL后面。服務器端應當在JSON數據前加上回調函數名,以便完成一個有效的JSONP請求。如果要指定回調函數的參數名來取代默認的callback。

注意,JSONP是JSON格式的擴展。他要求一些服務器端的代碼來檢測并處理查詢字符串參數。

HTML

在本例中,為了演示跨域提交數據,我們假設A網站域名為www.helloweba.com,B網站域名為demo.helloweba.com。我們在A網站創建一個簡單的表單,用于提交用戶信息。

  1. <form id="myform" action="#" method="post">   
  2.    <p><label>姓名:</label><input type="text" class="input" name="username" /></p>   
  3.    <p><label>性別:</label><input type="radio" name="sex" value="1" checked="checked" /> 男生   
  4.     <input type="radio" name="sex" value="2" /> 女生 </p>   
  5.    <p><label>年齡:</label><input type="text" class="input" name="age" /></p>   
  6.    <p><input type="submit" class="btn" value="提 交" /></p>   
  7. </form>    

jQuery

當用戶填寫完畢表單并點擊“提交”按鈕時,使用jQuery獲取表單信息,并通過getJSON提交給B網站,請看代碼:

  1. $(function(){   
  2.     $("#myform").submit(function(){   
  3.         var data = $(this).serialize(); //序列化表單數據   
  4.         $.getJSON("http://demo.helloweba.com/jsonp.php?callback=?",data,function(json){   
  5.             var msg = '';   
  6.             if(json){   
  7.                var  sex = json.sex==1"男生":"女生";   
  8.                msg = "< id='result'><strong>提交成功!</strong><br/>姓名:   
  9.                "+json.username+"<br/>性別:"+sex+"<br/>年齡:"+json.age+"</>"   
  10.             }else{   
  11.                msg = "服務器忙,請稍候再試!";   
  12.             }   
  13.             $("#myform").after(msg); //將返回信息插入頁面對應的元素后   
  14.         });   
  15.         return false;   
  16.     });   
  17. });   

從代碼中可以看出,首先將表單數據序列化,獲得json格式的表單數據,然后通過getJSON將數據發送給B網站URL:http://demo.helloweba.com/jsonp.php?callback=?,注意URL后面有個callback=?,將請求轉換為一個JSONP請求。然后根據B網站處理結果響應,并將響應結果動態顯示在A網站的表單提交頁面。

PHP

本例中,B網站的jsonp.php程序獲取A網站提交過來的表單數據,并將數據進行必要的處理(如有需要,可將數據過濾并插入數據庫中),然后返回JSON格式的數據給A網站的表單提交頁面。

  1. $result['username'] = $_GET['username'];   
  2. $result['sex'] = $_GET['sex'];   
  3. $result['age'] = $_GET['age'];   
  4. echo $_GET['callback'].'('.json_encode($result).')';   

如果處理成功,會返回這樣一串字符串:jsonp1331385001001({"username":"\u5929\u70ed\u7279","sex":"1","age":"28"})。

【編輯推薦】

 

 

責任編輯:張偉 來源: Helloweba
相關推薦

2011-07-22 09:51:51

iPhone FROM 表單

2016-09-27 19:28:37

2009-07-02 15:12:39

2009-07-03 14:41:03

2016-12-13 13:54:10

EasyUI form數據加載

2024-08-02 08:21:52

Spring項目方式

2023-04-26 08:18:48

FormPrompt表單更改

2021-06-15 07:32:59

Cookie和Sess實現跨域

2011-04-19 10:32:27

MVCjQuery

2009-12-01 18:02:41

PHP表單數組

2009-05-21 14:47:38

WEB開發JsonAjax

2014-08-19 10:36:02

AngularCORS

2021-09-14 18:33:39

React 數據交互

2010-06-10 18:08:58

2009-07-02 11:29:22

JSP技術表單數據存儲

2011-05-26 13:10:30

JSONPJSON

2009-07-29 16:40:50

Ajax提交asp.n

2020-12-31 08:14:39

VueAxiosJavaScript

2011-11-07 11:15:31

2010-01-22 14:59:40

VB.NET表單自動提
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 粉嫩在线| 亚洲成人免费视频在线观看 | 久草视频观看 | 中文字幕在线观看国产 | 久久99久久 | 日本一区二区电影 | 丁香久久 | 欧美久久一区二区三区 | 国产精品精品久久久 | 成人免费大片黄在线播放 | 国产视频中文字幕 | 国产精品久久久久久久久久久久久 | 91av在线免费播放 | 久久国产精品99久久久久久丝袜 | 久久亚洲一区二区 | 国产一级一级毛片 | 黄色毛片在线观看 | 国产剧情一区二区三区 | 中文字幕 国产 | 日日夜夜精品视频 | 国产欧美综合在线 | 欧美自拍视频 | 色女人天堂 | japan21xxxxhd美女 日本欧美国产在线 | 中文字字幕一区二区三区四区五区 | 国产精品99久久久久久动医院 | 色中文在线 | 性高湖久久久久久久久aaaaa | 91在线精品视频 | av手机免费在线观看 | 999精品在线观看 | 日韩欧美大片 | 男女羞羞视频在线看 | 成人1区2区 | 99久久国产| 99热这里| 欧美在线a | 国产美女在线播放 | 希岛爱理在线 | 九九热精品视频 | 中文av电影 |