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

发布时间 - 2026-01-11 01:11:33    点击率:

摘要

在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请求设置请求头与请求参数转换的设置,这样可以在其他地方方便使用。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# angularjs  # http  # post  # angularjs的http  # 解决angular的$http.post()提交数据时后台接收不到参数值问题的方法  # 对比分析AngularJS中的$http.post与jQuery.post的区别  # Angularjs中$http以post请求通过消息体传递参数的实现方法  # 后端接收不到AngularJs中$http.post发送的数据原因分析及解决办法  # AngularJS下$http服务Post方法传递json参数的实例  # AngularJS $http模块POST请求实现  # AngularJS $http post 传递参数数据的方法  # angularJS 发起$http.post和$http.get请求的实现方法  # AngularJS封装$http.post()实例详解  # Angular利用HTTP POST下载流文件的步骤记录  # 服务端  # 转化为  # 就会  # 总会  # 有必要  # 不做  # 我们现在  # 看一下  # 用户登录  # 大家多多  # 就与  # 来写  # 出现了  # 客户端  # 平时  # 就在这里  # _code  # Json  # Form  # userPwd 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  图册素材网站设计制作软件,图册的导出方式有几种?  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  CSS3怎么给轮播图加过渡动画_transition加transform实现【技巧】  ChatGPT 4.0官网入口地址 ChatGPT在线体验官网  如何确认建站备案号应放置的具体位置?  详解vue.js组件化开发实践  Android GridView 滑动条设置一直显示状态(推荐)  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  Bootstrap整体框架之CSS12栅格系统  PHP 500报错的快速解决方法  音响网站制作视频教程,隆霸音响官方网站?  Laravel中间件如何使用_Laravel自定义中间件实现权限控制  php在windows下怎么调试_phpwindows环境调试操作说明【操作】  Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】  七夕网站制作视频,七夕大促活动怎么报名?  php静态变量怎么调试_php静态变量作用域调试技巧【解答】  Laravel路由怎么定义_Laravel核心路由系统完全入门指南  微信小程序 HTTPS报错整理常见问题及解决方案  Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践  Laravel的.env文件有什么用_Laravel环境变量配置与管理详解  jQuery validate插件功能与用法详解  Python数据仓库与ETL构建实战_Airflow调度流程详解  Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试  英语简历制作免费网站推荐,如何将简历翻译成英文?  Linux安全能力提升路径_长期防护思维说明【指导】  如何快速搭建自助建站会员专属系统?  html5audio标签播放结束怎么触发事件_onended回调方法【教程】  Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程  在线制作视频的网站有哪些,电脑如何制作视频短片?  绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信  如何在万网ECS上快速搭建专属网站?  javascript中的数组方法有哪些_如何利用数组方法简化数据处理  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  javascript中的try catch异常捕获机制用法分析  如何在腾讯云服务器快速搭建个人网站?  如何用y主机助手快速搭建网站?  如何快速搭建安全的FTP站点?  详解MySQL数据库的安装与密码配置  如何破解联通资金短缺导致的基站建设难题?  Claude怎样写结构化提示词_Claude结构化提示词写法【教程】  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  如何利用DOS批处理实现定时关机操作详解  如何在建站宝盒中设置产品搜索功能?  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  动图在线制作网站有哪些,滑动动图图集怎么做?  php结合redis实现高并发下的抢购、秒杀功能的实例  Laravel storage目录权限问题_Laravel文件写入权限设置  Laravel如何实现用户密码重置功能?(完整流程代码)