對比分析AngularJS中的$http.post與jQuery.post的區別,angularjshttp.post

來源:互聯網
上載者:User

對比分析AngularJS中的$http.post與jQuery.post的區別,angularjshttp.post

很多時候我們需要用ajax提交post資料,angularjs與jq類似,也有封裝好的post。

但是jQuery的post明顯比angularjs的要簡單一些,人性化一些。

AngularJS:

複製代碼 代碼如下:
$http.post('do-submit.php',myData)
.success(function(){
    // some code
});

jQuery:

複製代碼 代碼如下:
$.post('do-submit.php', myData, function() {
    // some code
});

看起來沒什麼區別吧?可是,用angularjs的$http提交的資料,在php伺服器端卻無法通過$_REQUEST/$_POST擷取到,而需要用:

複製代碼 代碼如下:
$params = json_decode(file_get_contents('php://input'),true);

來擷取。什麼原因呢?

這是因為兩者的post對header的處理有所不同……jQuery會把作為JSON對象的myData序列化,例如:

複製代碼 代碼如下:
var myData = { a : 1, b : 2 };
// jQuery在post資料之前會把myData轉換成字串:"a=1&b=2"

而Angular不會。

解決方案是什嗎?

1.引入jquery,前提是目標使用者不介意多載入一個幾十K的指令碼。(不推薦)

2.在伺服器端(PHP)通過  $params = json_decode(file_get_contents('php://input'),true);   擷取參數,小項目可以,大項目要一個一個改。(不推薦)

3.修改Angular的$httpProvider的預設處理:http://victorblog.com/2012/12/20/make-angularjs-http-service-behave-like-jquery-ajax/  (為了便於以後的管理,這是最好的辦法)

小夥伴們是否對AngularJS中的$http.post與jQuery.post的區別有了進一步的認識了呢,希望大家讀完本文能夠有所得。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.