[轉][Angularjs]$http.post與$.post


本文轉自:https://www.cnblogs.com/wolf-sun/p/6878868.html

摘要

在angularjs發送post請求的時候,確實很困惑,在傳遞json數據的時候,總會遇到在服務端無法接受到參數的情況,這里有必要與$.post進行比較學習一下。

一個例子

這里模擬登錄的一個場景,post用戶名與密碼,服務端接受賬戶並直接返回到客戶端不做其它業務處理。

使用angularjs版本

/*
 AngularJS v1.2.15
 (c) 2010-2014 Google, Inc. http://angularjs.org
 License: MIT
*/

服務端

復制代碼
    public class AccountController : Controller
    {

        // GET: /<controller>/
        public IActionResult Login()
        {
            return View();
        }
        [HttpPost]        
        public IActionResult Login(string userName,string userPwd)
        {
            var resut = Request.Form;
            return Json(new { _code = 200, _msg = "Login success", name = userName, password = userPwd });
        }
    }
復制代碼

$.post

首先使用$.post的方式,直接提交賬戶密碼

   $.post("@Url.Content("~/Account/Login")",{ userName: "2342342", userPwd:"2sssdfs" },function (data) {
            console.log(data);
        });

響應

這里我們看一下請求體

那么我們現在看看angularjs的$http.post的情況,到底區別在哪兒?

復制代碼
@{
    Layout = null;
}
<!DOCTYPE html>
<html ng-app="login">
<head>
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>IT怪O 用戶登錄</title>
    <link href="~/lib/bootstrap/dist/css/bootstrap.css" rel="stylesheet" />
    <script src="~/js/angular.min.js"></script>
    <script>
        angular.module("login", []).controller("LoginController", function ($http, $scope) {
            $scope.Login = function () {
                var data = { userName: $scope.userName, userPwd: $scope.userPwd };

                var config = {
                    headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
                    //transformRequest: function (obj) {
                    //    var str = [];
                    //    for (var p in obj) {
                    //        str.push(encodeURIComponent(p) + "=" + encodeURIComponent(obj[p]));
                    //    }
                    //    return str.join("&");
                    //}
                };
                console.log(data);
                $http.post("@Url.Content("~/Account/Login")", data, config).success(function (data) {
                    console.log(data);
                });
            };

        });
    </script>
</head>
<body>
    <div ng-controller="LoginController">
        <input type="text" placeholder="用戶名" ng-model="userName" value="" />
        <input type="password" placeholder="密碼" ng-model="userPwd" value="" />
        <button ng-click="Login()">登錄</button>
    </div>
</body>
</html>
復制代碼

登錄

出現了,處於習慣的原因,平時就會這樣來寫$http.post的。但結果並不是想要的。那么咱們與$.post對比一下請求體。

看到沒?差別就在這里。

發現問題了,那么我們就要轉化為$.post提交參數的方式。幸好,angularjs中$http.post提供了一個轉化參數的transformRequest方法,可以在config中加上該參數:

復制代碼
   var config = {
                    headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
                    transformRequest: function (obj) {
                        var str = [];
                        for (var p in obj) {
                            str.push(encodeURIComponent(p) + "=" + encodeURIComponent(obj[p]));
                        }
                        return str.join("&");
                    }
                };
復制代碼

它的作用就是將提交的參數轉化為$.post提交參數的方式。這樣看到的請求體中參數就與$.post相同了。

可以在全局進行設置

復制代碼
    <script>
        angular.module("login", []).controller("LoginController", function ($http, $scope) {
            $scope.Login = function () {
                var data = { userName: $scope.userName, userPwd: $scope.userPwd };
                console.log(data);
                $http.post("@Url.Content("~/Account/Login")", data).success(function (data) {
                    console.log(data);
                });
            };

        }).config(function ($httpProvider) {          
            $httpProvider.defaults.transformRequest = function (obj) {
                var str = [];
                for (var p in obj) {
                    str.push(encodeURIComponent(p) + "=" + encodeURIComponent(obj[p]));
                }
                return str.join("&");
            };
            $httpProvider.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded; charset=utf-8';
        });
    </script>
復制代碼

總結

angularjs在進行post請求的時候要進行參數配置。關於angularjs的post請求,建議在初始化模塊的時候對post請求設置請求頭與請求參數轉換的設置,這樣可以在其他地方方便使用。

參考

http://stackoverflow.com/questions/12190166/angularjs-any-way-for-http-post-to-send-request-parameters-instead-of-json

  • 博客地址:http://www.cnblogs.com/wolf-sun/ 
    博客版權:如果文中有不妥或者錯誤的地方還望高手的你指出,以免誤人子弟。如果覺得本文對你有所幫助不如【推薦】一下!如果你有更好的建議,不如留言一起討論,共同進步! 再次感謝您耐心的讀完本篇文章。
 
分類:  [Angularjs]


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM