• web实现数据交互的几种常见方式


    前言

          在当今社会,作为一名前端程序猿,并不是一昧的去制作静态页面就可以满足滴;你说你会制作网页,好吧,只能说你算是一个前端程序猿。但这是你作为一个程序猿最基本的能力,并不会为你进行加分;

      我们都明白,要想提高竞争力,提高自己的技能是十灰重要的。前后台的数据交互就是一个很好的加分项。今天,就带大家一起了解一下web前端实现数据交互的几种方式;

    一、Ajax

    作为一个前端程序猿,对于各种JS框架和各种库肯定不陌生。原生js的ajax以及jQuery的ajax都是十分常用的数据交互的方式;

    1.1原生JS的Ajax

    大家可能对原生JS比较陌生,毕竟相对于jQuery的ajax,原生的确实有些复杂,不够jQuery的ajax是由原生的ajax封装而来。由此可见了解原生的ajax是十分必要的;

    首先,要了解异步的javascript和xml,核心对象为XMLHttpRequest.

    接下啦,给大家介绍XMLHttpRequest中的属性与方法:

    XMLHttpRequest属性:

    二、XMLHttpRequest方法:

    接下来,把栗子中的步骤整理一下:

    第一步:获得XMLHttpRequest对象;

    var ajax = new XMLHttpRequest();

    第二步:设置状态监听函数

    ajax.onreadystatechange = function(){}

    第三步:open一个请求:

     其中,第一个参数为传递方式:get/post;

    第二个参数:请求数据的url地址;

    第三个参数:true/false。true表示异步请求。false表示同步请求

    ajax.open("GET","h5.json",true); 

    第四步:send一个请求。可以发送对象和字符串,不需要传递数据发送null;

    ajax.send(null);

    第五步,在监听函数中,判断readyState==4 && status == 200表示请求成功;

    if (ajax.readyState == 4 && ajax.status == 200) {}

    第六步,使用ajax.responseText、ajax.responseXML接收响应数据,并使用原生js操作DOM进行显示;

    console.log(JSON.parse(ajax.responseText));

    直接上栗子:

     1 <!DOCTYPE html>
     2 <html>
     3     <head>
     4         <meta charset="UTF-8">
     5         <title></title>
     6         <script type="text/javascript">
     7             //第一步:获得XMLHttpRequest对象
     8             var ajax = new XMLHttpRequest();
     9             
    10             //第二步:设置状态监听函数
    11             ajax.onreadystatechange = function(){
    12                 //console.log(ajax.readyState);
    13                 //console.log(ajax.status);
    14                 //第五步,在监听函数中,判断readyState==4 && status == 200表示请求成功;
    15                 if (ajax.readyState == 4 && ajax.status == 200) {
    16                     //第六步,使用ajax.responseText、ajax.responseXML接收响应数据,并使用原生js操作DOM进行显示
    17                     //console.log(ajax.responseText);
    18                     //console.log(ajax.responseXML);//返回不是XMl,显示null
    19                     console.log(JSON.parse(ajax.responseText));
    20                     //console.log(eval("("+ajax.responseText+")"));
    21                     
    22                     
    23                 }
    24             }
    25             
    26             //第三步:open一个请求
    27             ajax.open("GET","h5.json",true); //true表示异步请求。false表示同步请求
    28             
    29             //第四步:send一个请求。可以发送对象和字符串,不需要传递数据发送null;
    30             ajax.send(null);
    31             
    32             var str = "alert('111')";
    33             eval(str);
    34             eval("alert('111')");
    35             
    36             var json1 = "{'name':'zhangsan'}";
    37             console.log(eval("("+json1+")"));
    38         </script>
    39     </head>
    40     <body>
    41     </body>
    42 </html>

     json:

     1 [
     2     {
     3         "name": "zhangsan",
     4         "age": 17,
     5         "hobby": [
     6             "吃",
     7             "喝",
     8             "玩",
     9             "乐"
    10         ],
    11         "score":{
    12             "math":78,
    13             "chinese":89
    14         }
    15     },
    16     {
    17         "name": "zhangsan",
    18         "age": 17,
    19         "hobby": [
    20             "吃",
    21             "喝",
    22             "玩",
    23             "乐"
    24         ],
    25         "score":{
    26             "math":78,
    27             "chinese":89
    28         }
    29     },
    30     {
    31         "name": "zhangsan",
    32         "age": 17,
    33         "hobby": [
    34             "吃",
    35             "喝",
    36             "玩",
    37             "乐"
    38         ],
    39         "score":{
    40             "math":78,
    41             "chinese":89
    42         }
    43     }
    44    
    45 ]

    结果:

     

    1.1.2解析json的两种方式

     在解析json的时候,通常我们使用JSON.parse()进行解析;但是,有很多程序猿使用eval()来解析json;

    1、eval函数用于将字符串中的代码解析出来并执行
    当使用eval函数解析JSON字符串时,需要在函数内部将JSON字符串用()拼接
    eval("("+json1+")")表示eval函数中的字符串不是用于执行,而是进行字符串解析

    eval("("+json1+")") = JSON.parse(json1);

     举个小例子:

    1 var json1 = "{'name':'zhangsan'}";
    2  console.log(eval("("+json1+")"));

    结果:

    1.2jQuery中的Ajax

     $.ajax():是JQuery最底层的ajax函数,参数接收一个大对象。对象里面的属性和方法,表示ajax请求的相关设置:

    ① url : 请求远程文件的路径
    ② type: Ajax请求的类型,可选值 get/post
    ③ data: 对象格式。向后台发送一个对象,表示传递的数据。
    常用与type为"post"的请求方式;
     如果type为"get",可以直接使用?追加在URL的后面。
    ④ dataType :预期后台返回什么类型的数据。
    "text"-字符串 "json"-JSON对象
     ⑤ success: 请求成功的回调函数。参数接受一个data,表示后台返回的数据。
     ⑥ error : 请求失败的时候的回调函数
     ⑦ statusCode : 接受一个对象,对象的键值对是status状态码和对应的回调函数,表示当请求状态码是对应数
    字时,执行具体的操作函数。
    200-正常请求成功 404-页面没有找到 500-服务器内部错误。

    再再举个栗子:

    <script type="text/javascript">
        $(function(){
            
            $.ajax({
                url : "url",
                type: "post",
                data : {
                    name : "李四",
                    age : 28
                },
                //dataType : "json",
                success : function(data){
                    // JQuery中吧JSON字符串转成JSON对象
                    var jsons = $.parseJSON(data);
                    console.log(jsons);
                },
                error: function(){
                    alert("请求失败啦!");
                },
                statusCode:{
                    "404":function(){
                        alert("404表示页面没有找到");
                    },
                    "500":function(){
                        alert("500表示服务器内部错误");
                    },
                    "200":function(){
                        alert("200表示请求成功");
                    }
                }
            });
    </script>
            


    1.2.2$.post/$.get

    在jQuery中,还进一步封装了Ajax,$.get();  $.post(); 这两个函数,是在$.ajax()的基础上进行封装而来。可以直接默认发送get请求或post请求;

    接受四个参数:
    ① 请求的URL路径。 相当于$.ajax()里面的url;
    ② 向后台传递的数据。 相当于$.ajax()里面的data;
    ③ 请求成功的回调函数。 相当于$.ajax()里面的success;
    ④ 预期返回的数据类型。 相当于$.ajax()里面的dataType;

    疯狂的举栗子:

    $.post("Surl",{data:"aaa"},function(data){
                console.log(data);
            },"json");
    二、AngularJS中的$http

    在上篇的AngularJS中小编讲了一下$http,今天再来复习一遍;AngularJS中的$http的基本样式比较简单,

    复制代码
    1 $http({
    2 method:"get/post", /*请求的方法*/
    3 url:" " /*请求的地址*/
    4 }).then(function(classes){
    5 /*请求成功的回调函数*/
    6 },function(){
    7 /*请求失败的回调函数*/
    8 });
    复制代码

    直接上栗子:

    复制代码
    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title></title>
        </head>
        <body ng-app="app" ng-controller="ctrl">
            <table width="400px"border="1"style="border-collapse: collapse;">
                <tr>
                    <th>姓名</th>
                    <th>年龄</th>
                    <th>兴趣</th>
                    <th>语文成绩</th>
                    <th>数学成绩</th>
                    <th>总分</th>    
                </tr>
                <tr ng-repeat="item in classes|orderBy:'score.chinese+score.math'">
                    <td>{{item.name}}</td>
                    <td>{{item.age}}</td>
                    <td>{{item.hobby}}</td>
                    <td>{{item.score.math}}</td>
                    <td>{{item.score.chinese}}</td>
                    <td>{{item.score.math+item.score.chinese}}</td>
                </tr>
                
            </table>
        </body>
        
        <script type="text/javascript" src="js/angular.js"></script>
        <script type="text/javascript">
            angular.module("app",[])
            .controller("ctrl",function($scope,$http){
                $http({
                    method:"get", /*请求的方法*/
                    url:"AngularJs.json" /*请求的地址*/
                }).then(function(classes){
                    /*请求成功的回调函数*/
                    $scope.classes=classes.data;
                    
    //                $scope.name = classes.data.name;
                    alert("请求成功!");
                },function(){
                    /*请求成功的回调函数*/
                    alert("请求失败");
                });
                
          });
    </script> </html>
    复制代码

    json:

    复制代码
     1 [
     2     {
     3         "name": "张三",
     4         "age": 17,
     5         "hobby": [
     6             "吃",
     7             "喝",
     8             "玩",
     9             "乐"
    10         ],
    11         "score":{
    12             "math":48,
    13             "chinese":59
    14         }
    15     },
    16     {
    17         "name": "张三",
    18         "age": 17,
    19         "hobby": [
    20             "吃",
    21             "喝",
    22             "玩",
    23             "乐"
    24         ],
    25         "score":{
    26             "math":88,
    27             "chinese":99
    28         }
    29     },
    30     {
    31         "name": "张三",
    32         "age": 17,
    33         "hobby": [
    34             "吃",
    35             "喝",
    36             "玩",
    37             "乐"
    38         ],
    39         "score":{
    40             "math":68,
    41             "chinese":89
    42         }
    43     },
    44     {
    45         "name": "张三",
    46         "age": 17,
    47         "hobby": [
    48             "吃",
    49             "喝",
    50             "玩",
    51             "乐"
    52         ],
    53         "score":{
    54             "math":78,
    55             "chinese":89
    56         }
    57     }
    58 ]
    复制代码

    结果:

    当然,他也有简写形式:

    $http.get('/someUrl', config).then(successCallback, errorCallback);
    $http.post('/someUrl', data, config).then(successCallback, errorCallback);

    举个栗子:

    复制代码
    1             $http.get("angularJs.json",{/*需要传递到后台的参数*/}).then(function(){
    2                 alert("请求成功!")
    3                 },function(){
    4                 alert("请求失败!");
    5             })
    6         })
    7         
    复制代码
    三、表单提交的get/post请求

    在最开始的前端学习中,表单是很重要的一部分。要知道,表单的提交过程也是想后台的一种数据交互的过程;今天,就来看一下表单请求到PHP;

    3.1POST表单提交

     在http中,有个HTTP POST变量:$_POST,其作用就是获取通过前台post发送的数据;

    再次疯狂的举栗子:

     1 <!DOCTYPE html>
     2 <html>
     3     <head>
     4         <meta charset="UTF-8">
     5         <title></title>
     6     </head>
     7     <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
     8     <body>
     9         <!--<form action="03-chaoQuanJuArray.php" method="get">-->
    10             用户名:<input type="text" name="username" />        
    11             密码:<input type="password" name="pwd" />
    12             <!--<input type="file" name="file" />-->
    13             <button id="btn">点击发送post请求</button>
    14         <!--</form>-->
    15         
    16         <script type="text/javascript">
    17             $("#btn").click(function(){
    18                 var username = $("input[name='username']").val();
    19                 var pwd = $("input[name='pwd']").val();
    20                 $.post("03-chaoQuanJuArray.php",{
    21                     "username":username,
    22                     "pwd":pwd,
    23                 },function(data){
    24                     alert(data);
    25                 })
    26             });
    27         </script>
    28 
    29     </body>
    30 </html>

    PHP:

    <?php
        header("Content-Type:text/html;charset=utf-8");
    if(isset($_POST["username"])&&isset($_POST["pwd"])){
            if($_POST["username"]=='zhang'&&$_POST["pwd"]==123){
                echo "登录成功";
            }else{
                echo "登录失败";
            }
        }

     结果:

    3.2表单Get请求数据

     最后疯狂的举例:

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title></title>
        </head>
        <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
        <body>
            <form action="03-chaoQuanJuArray.php" method="get">
                用户名:<input type="text" name="username" />        
                密码:<input type="password" name="pwd" />
                <!--<input type="file" name="file" />-->
                <button id="btn">点击发送post请求</button>
            </form>
            
            <script type="text/javascript">
                $("#btn").click(function(){
                    var username = $("input[name='username']").val();
                    var pwd = $("input[name='pwd']").val();
                    $.post("03-chaoQuanJuArray.php",{
                        "username":username,
                        "pwd":pwd,
                    },function(data){
                        alert(data);
                    })
                });
            </script>
    
        </body>
    </html>

     php:

    <?php
        header("Content-Type:text/html;charset=utf-8");
    if(isset($_GET["username"])&& isset($_GET["pwd"])){
            if($_GET["username"]=='zhang'&&$_GET["pwd"]==123){
                echo "登录成功";
            }else{
                echo "登录失败";
            }
        }

    结果:

     

    编者按

    今天小编就给大家介绍着四种前后台数据交互的方式。还有,localStorage和sessionStorage中的数据也是数据交互的一种方式。

    而在数据交互的过程中,经常会需要进行跨域请求,小编之后会给大家讲解。

  • 相关阅读:
    文档生成器
    jenkins多分支版本备份
    jenkins发布控制版本号和同步
    py导出时段报表
    jenkins多分支回滚总结文
    jenkins单分支版本备份
    k8s多pod查询日志脚本
    php 0425
    php 0418
    php 0422
  • 原文地址:https://www.cnblogs.com/zxt-17862802783/p/7787258.html
Copyright © 2020-2023  润新知