zoukankan      html  css  js  c++  java
  • 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发送的是Form Data;而angularjs默认发送的是json数据;

     

    产生原因已经找到;下面开始改造;

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

    其次对数据进行转换;这里我做了个简单的json到string转换的服务;

    改造后的代码如下:

    /*------创建angularjs应用------*/
    var app = angular.module('jjd',[]);
    
    /*创建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){//注入创建的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格式的数据的支持,有兴趣的小伙伴可以尝试一下;

  • 相关阅读:
    详解javascript的深拷贝与浅拷贝
    fis3+vue+pdf.js制作预览PDF文件或其他
    那一年,2020
    H5移动端IOS/Android兼容性总结,持续更新中…
    浏览器里点击复制到剪贴板的小方法
    elementUI upload 对图片的宽高做校验
    CSS实现核辐射警告标志
    github常用命令
    偶遇vue-awesome-swiper的坑
    gauge+python+vscode搭建自动化测试框架
  • 原文地址:https://www.cnblogs.com/wwlhome/p/5557244.html
Copyright © 2011-2022 走看看