国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 13:05:47
字體:
來源:轉載
供稿:網友

很多時候我們需要用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的區別有了進一步的認識了呢,希望大家讀完本文能夠有所得。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 四会市| 利津县| 新丰县| 太白县| 建平县| 延川县| 乌苏市| 蒙城县| 台山市| 会理县| 赤壁市| 盐山县| 伊宁市| 莎车县| 民丰县| 乃东县| 拜泉县| 伊川县| 西乌珠穆沁旗| 榆林市| 中方县| 澎湖县| 茶陵县| 徐汇区| 罗平县| 泾源县| 阿巴嘎旗| 沅江市| 陕西省| 通海县| 龙岩市| 尚志市| 天镇县| 邓州市| 永新县| 康平县| 宁晋县| 湖北省| 山阳县| 武穴市| 黄平县|