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

首頁 > 編程 > JavaScript > 正文

深入理解Angularjs中$http.post與$.post

2019-11-19 16:32:42
字體:
來源:轉載
供稿:網友

摘要

在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="external nofollow" 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請求設置請求頭與請求參數轉換的設置,這樣可以在其他地方方便使用。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宣威市| 龙江县| 宁明县| 渭南市| 儋州市| 开原市| 江山市| 新津县| 左贡县| 剑阁县| 蒲江县| 惠州市| 犍为县| 达拉特旗| 乌兰浩特市| 玛曲县| 广汉市| 牙克石市| 白水县| 内丘县| 梧州市| 广灵县| 济南市| 勐海县| 三门峡市| 康乐县| 枣强县| 集安市| 龙门县| 东海县| 宿松县| 建昌县| 子洲县| 青州市| 黑水县| 兴和县| 泸州市| 乐都县| 霞浦县| 岑巩县| 略阳县|