• JQuery中的load()、$.get()和$.post()详解 (转)


    load()

    1.载入HTML文档
    load()方法是jQuery中最为简单和常用的Ajax方法,能载入远程HTML代码并插入DOM中。
    它的结构为:

    load(url [,data][,callback])



    参数名称 类型 说明
    url String 请求HTML页面的URL地址
    data(可选) Object 发送至服务器的key/value数据
    callback(可选) Function 请求完成时的回调函数,无论请求成功或失败



    首先创建一个test.html文件,用于被load()方法加载并追加到页面中。

    test.html
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <title></title>
     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    </head>
    <body>
    <div class="comment">
     <h6>张三:</h6>
     <p class="para">沙发.</p>
    </div>
    <div class="comment">
     <h6>李四:</h6>
     <p class="para">板凳.</p>
    </div>
    <div class="comment">
     <h6>王五:</h6>
     <p class="para">地板.</p>
    </div>
    </body>
    </html>

    然后再建一个demo1.html,在上面添加两个元素:<button>用来触发Ajax事件,id为”resText”的元素用来显示追加的HTML内容。HTML代码如下:

    demo1.html
    • 1
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <title></title>
     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <style type="text/css">
    * { margin:0; padding:0;}
    body { font-size:12px;}
    .comment { margin-top:10px; padding:10px; border:1px solid #ccc;background:#DDD;}
    .comment h6 { font-weight:700; font-size:14px;}
    .para { margin-top:5px; text-indent:2em;background:#DDD;}
    </style>
     <!--   引入jQuery -->
    <script src="https://cdn.bootcss.com/jquery/1.7.1/jquery.min.js"></script>
    <script language="javascript" type="text/javascript">
      $(function(){
          $("#send").click(function(){
                  $("#resText").load("test.html");
          })
      })
    </script>
    </head>
    <body>
    <input type="button" id="send" value="Ajax获取" />
    
    <div  class="comment">
        已有评论:
    </div>
    <div id="resText" ></div>
    </body>
    </html>

    显然,load()方法完成了原本很繁琐的工作。开发人员只需要使用jQuery选择器为HTML片段指定目标位置,然后将要加载的文件的URL作为参数传递给load()方法即可。当单击按钮后,test.html页面的HTML内ring就会被加载并插入主页面<div id="resText"></div>的元素中。

    2.筛选载入的HTML文档
    上面的例子是将test.html页面中的内容都加载到id"resText"的元素里。如果只需要加载test.html页面内的某些元素,那么可以使用load()方法的URL参数来达到目的。通过为URL参数指定选择符,就可以很方便地从加载过来的HTML文档里筛选出所需要的内容。

    load()方法的URL参数的语法结构为:“url selector”。注意,URL和选择器之间有一个空格。

    例如只需要加载test.html页面中class为”para”的内容,可以将demo1.html中的

    $("#resText").load("test.html");
    • 1

    改为

    $("#resText").load("test.html  .para");
    • 1

    3.传递方法
    load()方法的传递方式根据参数data来自动指定。如果没有参数传递,则采用GET方式传递;反之,则会自动转换为POST方法。

    //无参数传递,则是GET方式
    $('#resText').load('test.php',function(){
        //...
    });
    //有参数传递,则是POST方式
    $('#resText').load('test.php',{name:'rain',age:'22'},function(){
        //...
    });

    4.回调函数
    对于必须在加载完成后才能继续的操作,load()方法提供了回调函数(callback),该函数有3个参数,分别代表请求返回的内容请求状态XMLHttpRequest对象,jQuery代码如下:

    $("#resText").load("test.html",function (responseText, textStatus, XMLHttpRequest){         
            alert(responseText);         //请求返回的内容
            alert(textStatus);          //请求状态:success,error
            alert(XMLHttpRequest);     //XMLHttpRequest对象
    });

    在load()方法中,无论Ajax请求是否成功,只要当请求完成(complete)后,回调函数(callback)就被触发。


    load()方法通常用来从Web服务器上获取静态的数据文件,然后这并不能体现Ajax的全部价值。在项目中,如果需要传递一些参数给服务器中的页面,那么可以使用$.get()或者$.post()或者$.ajax()方法。


    $.get()

    $.get()方法使用GET方式来进行异步请求。
    它的结构为:

    $.get(url[,data][,callback][,type])
    • 1
    参数名称类型说明
    url String 请求的HTML页的URL地址
    data(可选) Object 发送至服务器的key/value数据会作为QueryString附加到请求URL中
    callback(可选) Function 载入成功时回调函数(只有当Response的返回状态是success才调用该方法)自动将请求结果和状态传递给该方法
    type(可选) String 服务器端返回内容的样式,包括xml、html、script、json、text和_default

    我们用$.get()来实现评论的功能:

    get1.html
    • 1
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <title></title>
     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <style type="text/css">
    * { margin:0; padding:0;}
    body { font-size:12px;}
    .comment { margin-top:10px; padding:10px; border:1px solid #ccc;background:#DDD;}
    .comment h6 { font-weight:700; font-size:14px;}
    .para { margin-top:5px; text-indent:2em;background:#DDD;}
    </style>
     <!--   引入jQuery -->
    <script src="../scripts/jquery.js" type="text/javascript"></script>
    <script type="text/javascript">
    //<![CDATA[
        $(function(){
           $("#send").click(function(){
                $.get("get1.php", { 
                            username :  $("#username").val() , 
                            content :  $("#content").val()  
                        }, function (data, textStatus){
                            $("#resText").html(data); // 把返回的数据添加到页面上
                        }
                );
           })
        })
    //]]>
    </script>
    </head>
    <body>
    <form id="form1" action="#">
    <p>评论:</p>
     <p>姓名: <input type="text" name="username" id="username" /></p>
     <p>内容: <textarea name="content" id="content"  rows="2" cols="20"></textarea></p>
     <p><input type="button" id="send" value="提交"/></p>
    </form>
    
    <div  class='comment'>已有评论:</div>
    <div id="resText" >
    </div>
    
    </body>
    </html>
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    get1.html向get1.php发送get请求,服务器端get1.php的代码如下:

    <?php 
        header("Content-Type:text/html; charset=utf-8");
        echo "<div class='comment'><h6>{$_REQUEST['username']}:</h6><p class='para'>{$_REQUEST['content']}</p></div>";
    ?>

    由于服务器端get1.php返回的数据格式是一段HTML片段,因此并不需要经过处理就可以将新的HTML数据插入到主页面中。
    我们再来看一下get.html中的核心代码jQuery是如何完成get请求的:

    $(function(){
           $("#send").click(function(){
                $.get("get1.php", { 
                            username :  $("#username").val() , 
                            content :  $("#content").val()  
                        }, function (data, textStatus){
                            $("#resText").html(data); // 把返回的数据添加到页面上
                        }
                );
           })
        })

    我们可以看到在回调函数中,我们直接将返回回来的data(也就是HTML片段)直接在html中使用。

    HTML片段实现起来只需要很少的工作量,但这种固定的数据结构并不一定能够在其他的Web应用程序中得到重用。

    XML文档

    服务器端是如何接收数据然后返回XML的呢?
    代码如下:

    get2.php
    • 1
    <?php 
        header("Content-Type:text/xml; charset=utf-8");
        echo "<?xml version='1.0' encoding='utf-8'?>".
             "<comments>".
             "<comment username='{$_REQUEST['username'] }' >".
             "<content>{$_REQUEST['content']}</content>".
             "</comment>".
             "</comments>";
    ?>

    注意:由于服务器端返回的数据格式是XML文档,因此需要在服务端设置Content-Type类型,代码如下:

    header("Content-Type:text/xml; charset=utf-8");
    • 1

    对于服务器端返回的数据是XML格式的情况,我们需要对返回的数据进行处理,才能应用到HTML中,jQuery有强大的DOM处理能力,处理XML文档与处理HTML文档一样,也可以使用常规的attr()、find()、filter()以及其他方法。jQuery代码如下:

    $(function(){
      $("#send").click(function(){
        $.get("get2.php", { 
          username :  $("#username").val() , 
          content :  $("#content").val()  
        }, function (data, textStatus){
          var username = $(data).find("comment").attr("username");
          var content = $(data).find("comment content").text();
          var txtHtml = "<div class='comment'><h6>"+username+":</h6><p class='para'>"+content+"</p></div>";
          $("#resText").html(txtHtml); // 把返回的数据添加到页面上
        },'XML');
      });
    })

    返回数据格式为XML文档的过程实现起来比HTML片段要稍微复杂些,但XML文档的可移植性是其他数据格式无法比拟的,因此以这种格式提供的数据的重要性将极大提高。不过,XML文档体积相对较大,与其他文件格式相比,解析和操作它们的速度要慢一些。

    JSON文件
    之所以会出现这种数据格式的文件,很大程度上是因为XML文档体积大和难以解析。JSON文件和XML文档一样,也可以方便的被重用。而且,JSON文件非常简洁,也容易阅读。

    服务器端是如何接收数据然后返回JSON的呢?
    代码如下:

    get3.php
    • 1
    <?php 
        header("Content-Type:text/html; charset=utf-8");
        echo "{ "username" : "{$_REQUEST['username']}" , "content" : "{$_REQUEST['content']}"}" 
    ?>

    JSON的格式还是比较严格的,所以格式不能写错了。
    由于服务器端返回的数据格式是JSON文件,因此需要对返回的数据进行处理之后,才可以将新的HTML数据添加到主页面中。HTML文件其他部分还是一样,要修改的地方是jQuery部分,jQuery代码如下:

    $(function(){
          $("#send").click(function(){
                $.get("get3.php", { 
                    username :  $("#username").val() , 
                    content :  $("#content").val()  
                }, function (data, textStatus){
                    var username = data.username;
                    var content = data.content;
                    var txtHtml = "<div class='comment'><h6>"+username+":</h6><p class='para'>"+content+"</p></div>";
            $("#resText").html(txtHtml); // 把返回的数据添加到页面上
                },"json");
           });
        })

    在上面的代码中,将$.get()方法的第4个参数(type)设置为”json”来代表期待服务器返回的数据格式。

    对于服务器端返回HTML片段、XML数据、JSON数据的优缺点进行分析,可以的得知在不需要与其他应用程序共享数据的时候,使用HTML片段来提供返回数据一般来说是最简单的;如果数据需要重用,那么JSON文件是不错的选择,它在性能和文件大小方面具有优势,它是Web服务器领域的“世界语”,我们推荐使用JSON。

    $.post()

    它与$.get()方法的结构和使用方式都相同,不过它们之间仍然有以下区别。

    • GET请求会将参数跟在URL后进行传递,而POST请求则是作为HTPP消息的实体内容发送给Web服务器。当然,在Ajax请求中,这种区别对用户是不可见的
    • GET方式对传输的数据有大小限制(通常不能大于2KB),而使用POST方式传递的数据量要比GET方式大得多(理论上不受限制)
    • GET方式请求的数据会被浏览器缓存起来,因此其他人就可以从浏览器的历史记录中读取到这些数据,例如账号和密码等。在某种情况下,GET方式会带来严重的安全性问题,而POST方式相对来说就可以避免这些问题。
    • GET方式和POST方式传递的数据在服务器端的获取也不相同。在PHP中,GET方式的数据可以用$_GET[]获取,而POST方式可以用$_POST[]获取。两种方式都可以用$_REQUEST[]来获取。

    由于POST和GET方式提交的所有数据都可以通过$_REQUEST[]来获取,因此只需要改变jQuery函数,就可以将程序在GET请求和POST请求之间切换。
    代码如下:

    $(function(){
      $("#send").click(function(){
        $.post("post1.php", { 
          username :  $("#username").val() , 
          content :  $("#content").val()  
        }, function (data, textStatus){
          $("#resText").html(data); // 把返回的数据添加到页面上
        });
      })
    })

    load()、$.get()和$.post(),我们可以发现,$.get()和$.post()方法是jQuery中的全局函数,而在此之前讲的load()是对jQuery对象进行操作的。

    上面使用load()、$.get()和$.post()方法完成了一些常规的Ajax程序,如果还需要编写一些复杂的Ajax程序,那么就要用到jQuery中的$.ajax()方法。$.ajax()方法不仅能实现与load()、$.get()和$.post()方法同样的功能,而且还可以设定beforeSend()、error()、success()以及complete()回调函数,通过这些函数,可以给用户更多的Ajax提示信息。另外,还有一些参数,可以设置Ajax请求的超时时间或者页面的”最后更改”状态等。关于$.ajax()方法将在下一篇博客中讲解

    JQuery中的$.getScript()、$.getJson()和$.ajax()方法

  • 相关阅读:
    Object Files (.obj)
    使用IIS Microsoft的web服务器和ftp服务器
    关于matlab
    char, signed char, unsigned char的区别
    百度面试
    google笔试题_2011
    ioctl 函数与网络接口
    Unity之热更新:(三)XLua
    C#之设计模式:观察者模式
    C#:委托
  • 原文地址:https://www.cnblogs.com/liuxingleiyu/p/8169518.html
Copyright © 2020-2023  润新知