• jQuery教程


     

    jQuery教程 - Ajax之load()方法

    标签: jqueryajaxxmlhttprequesthtmlcallback
     分类:

      jQuery对Ajax操作进行了封装,在jQuery中$.ajax()方法属于最底层的方法,第2层是laod()、$.get()和$.post()方法,第3层是$.getScript()和$.getJSON()方法。

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

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

      load()方法参数解释见下表:

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

    1、 载入HTML文档

      首先创建一个名为test.html的HTML文件,为后台Ajax载入做准备。代码如下:

    [xhtml] view plain copy
    1. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
    2. <html>  
    3. <head>  
    4. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
    5. <title>Insert title here</title>  
    6. </head>  
    7. <body>  
    8.   
    9. <div class="comment">  
    10.     已有评论:  
    11. </div>  
    12. <div class="comment">  
    13.     <h6>张三:</h6>  
    14.     <class="para">沙发。</p>  
    15. </div>  
    16. <div class="comment">  
    17.     <h6>李四:</h6>  
    18.     <class="para">板凳。</p>  
    19. </div>  
    20. <div class="comment">  
    21.     <h6>王五:</h6>  
    22.     <class="para">地板。</p>  
    23. </div>  
    24.   
    25. </body>  
    26. </html>  

      然后新建一个空白页面,在上面添加两个元素:<button>按钮用来触发Ajax事件,id为“resText”的元素用来显示追加的HTML内容。接下来就是编写jQuery代码了。等DOM元素加载完毕,通过单击id为“send”的按钮来调用laod()方法,然后将test.html的内容加载到id为“resText”的元素里。那么代码如下:

    [xhtml] view plain copy
    1. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
    2. <html>  
    3. <head>  
    4. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
    5. <title>Insert title here</title>  
    6. <mce:script type="text/<a href="http://lib.csdn.net/base/javascript" class='replace_word' title="JavaScript知识库" target='_blank' style='color:#df3434; font-weight:bold;'>JavaScript</a>" src="/jquery-1.3.2.js" mce_src="jquery-1.3.2.js"></mce:script>  
    7. </head>  
    8. <body>  
    9.   
    10. <input type="button" id="send" value="Ajax获取" />  
    11. <div id="resText"></div>  
    12.   
    13. <mce:script type="text/javascript"><!--  
    14. $(document).ready(function(){  
    15.     $("#send").click(function(){  
    16.         $("#resText").load("test.html");  
    17.     });  
    18. });  
    19. // --></mce:script>  
    20.   
    21. </body>  
    22. </html>  

      当按钮被单击后,出现如下图的界面:

      

      显然,load()方法完成了原本很繁琐的工作。开发人员只需要使用jQuery选择器为HTML片段指定目标位置,然后将要加载的文件的URL作为参数传递给load()方法即可。

    2、 筛选载入的HTML文档

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

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

      例如只需要加载test.html页面中class为“para”的内容,可以使用以下代码来完成:

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

      运行效果则如下图:

      

    3、 传递方式

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

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

    4、 回调参数

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

    $("#resText").load("test.html",function(responseText,textStatus,XMLHttpRequest){
        //responseText:请求返回的内容
        //textStatus:请求状态:success、error、notmodified、timeout这4种
        //XMLHttpRequest:XMLHttpRequest对象
    });
  • 相关阅读:
    【Oracle 12c】最新CUUG OCP-071考试题库(58题)
    【Oracle 12c】最新CUUG OCP-071考试题库(57题)
    【Oracle 12c】最新CUUG OCP-071考试题库(56题)
    【Oracle 12c】最新CUUG OCP-071考试题库(55题)
    voip,
    处理xmpp 离线信息,
    流程,xmpp发送信息,
    折腾我几天的 消息状态,
    三者的区别,
    bundle,
  • 原文地址:https://www.cnblogs.com/KLYY/p/6772443.html
Copyright © 2020-2023  润新知