欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談angularjs $http提交數據探索

 更新時間:2017年01月20日 12:03:25   作者:一步小僧  
這篇文章主要介紹了淺談angularjs $http提交數據探索,具有一定的參考價值,感興趣的小伙伴們可以參考一下。

前兩天在搞自己的項目,前端js框架用的是angularjs框架;網站整的差不多的時候出事了;那就是當我用$http.post()方法向服務器提交一些數據的時候;后臺總是接收不到數據;

于是采用了其他方法暫時性替代一下;

今天正好有時間研究這個事情;網上查了很多資料;都試了試;都是不太好;但是還是給我提供了一些解決問題的思路;

正文開始:首先做了個demo如下;主要是為了比較他們的不同之處;

html如下:

<div class="container-fluid" data-ng-app="jjd" data-ng-controller="index">

 <div class="container">

  <div class="row">

    

   <div class="col-md-5">

    <p class="h4 text-center">jQ的$.post()提交</p>

    <p> </p>

    <div class="form-group">

     <label for="exampleInputEmail1">用戶名</label>

     <input type="text" ng-model="sdata.name" class="form-control" placeholder="用戶名">

    </div>

    <div class="form-group">

     <label for="">密碼</label>

     <input type="password" ng-model="sdata.pwd" class="form-control" placeholder="密碼">

    </div>

    <button type="button" class="btn btn-primary btn-block" ng-click="jPostData()">jQ提交</button>

   </div>

   <div class="col-md-2"> </div>

   <div class="col-md-5">

    <p class="h4 text-center">angularjs的$http.post()功能</p>

    <p> </p>

    <div class="form-group">

     <label for="exampleInputEmail1">用戶名</label>

     <input type="text" ng-model="sdata2.name" class="form-control" placeholder="用戶名">

    </div>

    <div class="form-group">

     <label for="">密碼</label>

     <input type="password" ng-model="sdata2.pwd" class="form-control" placeholder="密碼">

    </div>

    <button type="button" class="btn btn-primary btn-block" ng-click="aPostData()">$http提交</button>

   </div>

    

  </div>

 </div>

</div> 

js代碼如下:

var app = angular.module('jjd',[]);
app.controller('index',function($scope,$http){
 $scope.sdata = {
  name:'jQuery',
  pwd:'jQuery'
 };
 $scope.sdata2 = {
  name:'Angularjs',
  pwd:'Angularjs'
 };
 
 /*jQ的ajax提交*/
 $scope.jPostData = function(){
  //console.log($scope.sdata);
  $.post('/web/data.php',$scope.sdata,function(d){
   console.log(d);
  })
 };
 
 /*angularjs的$http提交*/
 $scope.aPostData = function(){
  
  $http({
   url: '/web/data.php',
   method: 'POST',
   data:$scope.sdata2
   }
  }).success(function(da){
   console.log(da);
  });
 };
});

后臺采用php的$_POST接收:

<?php
header("Content-type: text/html; charset=utf-8"); 
$aname = $_POST['name'];
$apwd = $_POST['pwd'];

$msg = array();
$msg['name'] = $aname;
$msg['pwd'] = $apwd;
echo json_encode($msg);
?>

服務器采用wampsever的本地啟動的本地服務器。致此,頁面服務搭建完畢;開始測試;

結果如圖:

從上圖的對比中可以看出后臺接收不到值得原因主要是1、2、3處不同;

其中1和2是請求的頭文件信息;

3是數據類型不同;jq發(fā)送的是Form Data;而angularjs默認發(fā)送的是json數據;

產生原因已經找到;下面開始改造;

首先針對1和2,在$http()的方法中配置header信息;

其次對數據進行轉換;這里我做了個簡單的json到string轉換的服務;

改造后的代碼如下:

/*------創(chuàng)建angularjs應用------*/
var app = angular.module('jjd',[]);

/*創(chuàng)建json格式到string的轉換服務*/
app.service('jsonToStr',function(){
 this.transform = function(jsonData){
  var string = '';
  
  for(str in jsonData){
   string = string + str +'=' + jsonData[str] +'&';
  }
  
  var _last = string.lastIndexOf('&');
  
  string = string.substring(0,_last);
  
  return string;
 };
});

/*---------首頁控制器--------*/
app.controller('index',function($scope,$http,jsonToStr){//注入創(chuàng)建的jsonToStr服務
 $scope.sdata = {
  name:'jQuery',
  pwd:'jQuery'
 };
 $scope.sdata2 = {
  name:'Angularjs',
  pwd:'Angularjs'
 };
 
 /*jQ的ajax提交*/
 $scope.jPostData = function(){
  //console.log($scope.sdata);
  $.post('/web/data.php',$scope.sdata,function(d){
   console.log(d);
  })
 };
 
 /*angularjs的$http提交*/
 $scope.aPostData = function(){
  //console.log(jsonToStr.transform($scope.sdata2));
  
  $http({
   url: '/web/data.php',
   method: 'POST',
   data:$scope.sdata2,
   data: jsonToStr.transform($scope.sdata2),//對提交的數據格式化
   headers: {
    'Accept': '*/*',
    'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
   }
  }).success(function(da){
   console.log(da);
  });
 };
});

致此,angularjs提交數據后臺接收不到的問題解決(只針對json數據格式);獻給奮斗中的小伙伴;

這個問題應該還有一種思路;就是在服務端進行對獲取json格式的數據的支持,有興趣的小伙伴可以嘗試一下;

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

相關文章

  • AngularJS表單編輯提交功能實例

    AngularJS表單編輯提交功能實例

    這篇文章主要介紹了AngularJS表單編輯提交功能實例,本文講解如何修改表單的默認值,需要的朋友可以參考下
    2015-02-02
  • 手動初始化Angular的模塊與控制器

    手動初始化Angular的模塊與控制器

    本文主要介紹了手動初始化Angular的模塊與控制器的方法,具有一定的參考價值,下面跟著小編一起來看下吧
    2016-12-12
  • 深入理解Angularjs中的$resource服務

    深入理解Angularjs中的$resource服務

    大家可以知道在Angularjs中可以用$http同服務器進行通信,功能上比較簡單,AngularJS還提供了另外一個可選的服務$resource,使用它可以非常方便的同支持restful的服務單進行數據交互。這篇文章主要給大家深入的介紹了Angularjs中的$resource服務。
    2016-12-12
  • 詳解在Angular4中使用ng2-baidu-map的方法

    詳解在Angular4中使用ng2-baidu-map的方法

    這篇文章主要介紹了在Angular4中使用ng2-baidu-map的方法,本文分步驟給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06
  • AngularJS集合數據遍歷顯示的實例

    AngularJS集合數據遍歷顯示的實例

    下面小編就為大家分享一篇AngularJS集合數據遍歷顯示的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • 在Angular中如何監(jiān)聽某個值的變化

    在Angular中如何監(jiān)聽某個值的變化

    這篇文章主要介紹了在Angular中如何監(jiān)聽某個值的變化問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • angular中實現(xiàn)li或者某個元素點擊變色的兩種方法

    angular中實現(xiàn)li或者某個元素點擊變色的兩種方法

    本篇文章主要介紹了angular中實現(xiàn)li或者某個元素點擊變色的兩種方法,非常具有實用價值,需要的朋友可以參考下
    2017-07-07
  • 詳解如何為你的angular app構建一個第三方庫

    詳解如何為你的angular app構建一個第三方庫

    這篇文章主要介紹了詳解如何為你的angular app構建一個第三方庫,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • Angular實現(xiàn)可刪除并計算總金額的購物車功能示例

    Angular實現(xiàn)可刪除并計算總金額的購物車功能示例

    這篇文章主要介紹了Angular實現(xiàn)可刪除并計算總金額的購物車功能,涉及AngularJS事件響應、元素遍歷與數值運算等相關操作技巧,需要的朋友可以參考下
    2017-12-12
  • Angular之toDoList的實現(xiàn)代碼示例

    Angular之toDoList的實現(xiàn)代碼示例

    本篇文章主要介紹了Angular之toDoList的實現(xiàn)代碼示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12

最新評論