jQuery中$.get、$.post、$.getJSON和$.ajax的用法

来源:互联网 发布:乐清知临寄宿学校 编辑:程序博客网 时间:2024/05/20 05:08

1、$.get

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

$.get( url [, data] [, callback] )

解释一下这个函数的各个参数:

url:string类型,ajax请求的地址。

data:可选参数,object类型,发送至服务器的key/value数据会作为QueryString附加到请求URL中。

callback:可选参数,function类型,当ajax返回成功时自动调用该函数。

最后写一个$.get()的实例供大家参考:

 

 

$.get(    "submit.aspx",

         {        id:     '123',        name:   '青藤园',    },

         function(data,state){        

         //这里显示从服务器返回的数据        

        alert(data);       

         //这里显示返回的状态     

        alert(state);    })

2、$.post()

 

$.post()方法使用POST方式来进行异步请求,它的语法结构为:

$.post(url,[data],[callback],[type])

这个方法和$.get()用法差不多,唯独多了一个type参数,那么这里就只介绍type参数吧,其他的参考上面$.get()的。

type:type为请求的数据类型,可以是html,xml,json等类型,如果我们设置这个参数为:json,那么返回的格式则是json格式的,如果没有设置,就和$.get()返回的格式一样,都是字符串的。

最后写一个$.post()的实例供大家参考:

 

 

$.post(    "submit.aspx",
        {        id:     '123',        name:   '青藤园',    },
        function(data,state){        
        //这里显示从服务器返回的数据        

              alert(data);       

        //这里显示返回的状态      

              alert(state);   

         },    

        "json");

3、$.getJSON()

 

$.getJSON()是专门为ajax获取json数据而设置的,并且支持跨域调用,其语法的格式为:

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

url:string类型, 发送请求地址
data :可选参数, 待发送 Key/value 参数 ,同get,post类型的data
callback :可选参数,载入成功时回调函数,同get,post类型的callback

JSON 是一种理想的数据传输格式,它能够很好的融合与JavaScript或其他宿主语言,并且可以被JS直接使用。使用JSON相比传统的通过 GET、POST直接发送“裸体”数据,在结构上更为合理,也更为安全。至于jQuery的getJSON()函数,只是设置了JSON参数的 ajax()函数的一个简化版本。这个函数也是可以跨域使用的,相比get()、post()有一定优势。另外这个函数可以通过把请求url写 成"myurl?callback=X"这种格式,让程序执行回调函数X。

提示:数据最终还是通过url后面通过get方式发送数据出去的,这就决定了,发送的data数据量不能太多,否则造成url太长接收失败(getJSON方式是不可能有post方式递交的)。

4、$.ajax()

$.ajax()是jquery中通用的一个ajax封装,其语法的格式为:

$.ajax(options)

其中options是一个object类型,它指明了本次ajax调用的具体参数,这里我把最常用的几个参数附上

 

 

$.ajax({

        url: 'submit.aspx',

        datatype: "json",

        type: 'post',

        success: function (e) {

        //成功后回调

            alert(e);

         },

        error: function(e){

    //失败后回调

            alert(e);

        },

        beforeSend: function(){

 //发送请求前调用,可以放一些"正在加载"之类额话

            alert("正在加载");        

}})

好了,以上就是jquery实现ajax调用的几种方法,现在我把我最近新的一个小例子贴上来,这样更直观。

前台接收页面:

注意要引入jquery mobile 包

[html] view plaincopyprint?
  1. <html>  
  2. <head>  
  3. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
  4. <title>Insert title here</title>  
  5. <span style="color:#CC0000;"><script type ="text/javascript" src = "jquery-1.6.4.min.js"></script></span>  
  6. </head>  
  7. <script type = "text/javascript">  
  8.     $(function(){  
  9.         $("#button1").click(function(){  
  10.             //用getJSON方法获取后台传递过来的JSON对象数组  
  11.             <span style="color:#CC0000;">$.getJSON</span>("http://10.65.9.181:8090/jq_test_server/2.jsp",function(data){  
  12.                 //调用each方法进行数组遍历  
  13.                 $.each(data,function(index,item){  
  14.                     //alert(data);  
  15.                     //alert(item.username);  依次打印所有的username  
  16.                     //alert(item);  
  17.                     //打印出遍历的username的最后一个,因为之前的username会被后者覆盖//打印zxy  
  18.                     $("#button1").html(item.username);  
  19.                 });  
  20.             });  
  21.         });  
  22.         $("#button2").click(function(){  
  23.             //用get方法获取后台传递过来的json字符串,注意是字符串  
  24.             <span style="color:#CC0000;">$.get</span>("http://10.65.9.181:8090/jq_test_server/2.jsp",function(data){  
  25.                 //alert(data);  
  26.                 //将字符串转化为json对象  
  27.                 data = JSON.parse(data);  
  28.                 $("#button2").html(data[1].username);  
  29.                 });  
  30.         });  
  31.         $("#button3").click(function(){  
  32.             //用post方法获取后台传递过来的json字符串,注意是字符串  
  33.             <span style="color:#CC0000;">$.post</span>("http://10.65.9.181:8090/jq_test_server/2.jsp",function(data){  
  34.                 //alert(data);  
  35.                 //将字符串转化为json对象  
  36.                 data = JSON.parse(data);  
  37.                 $("#button3").html(data[1].username);  
  38.                 });  
  39.         });  
  40.         $("#button4").click(function(){  
  41.             //采用ajax方式获取json字符串  
  42.             <span style="color:#CC0000;">$.ajax</span>({  
  43.                 type:"GET",  
  44.                 url:"http://10.65.9.181:8090/jq_test_server/2.jsp",  
  45.                 success:function(data){  
  46.                     //强制转换为json对象  
  47.                     data = JSON.parse(data);  
  48.                     //打印的是对象数组里面的第一个值对应的username  
  49.                     $("#button4").html(data[0].username);  
  50.                 }  
  51.             });  
  52.         });  
  53.     });  
  54. </script>  
  55. <body>  
  56. <a id = "button1" href = "#">getJSON方法</a>  
  57. <a id = "button2" href = "#">get方法</a>  
  58. <a id = "button3" href = "#">post方法</a>  
  59. <a id = "button4" href = "#">ajax方法</a>  
  60. </body>  
  61. </html>  
后台2.jsp页面:(此处主要是测试前台接收json数据的几种方式,故后台没有分离,很简陋)

注意要引入org.json包

[java] view plaincopyprint?
  1. <span style="color:#000000;"><%@ page language="java" import="java.util.*,java.sql.*</span>,<span style="color:#CC0000;">org.json.*</span>"  
  2.     <span style="color:#000000;">pageEncoding="utf-8"%></span>  

[java] view plaincopyprint?
  1. <span style="color:#CC0000;">response.setHeader("Access-Control-Allow-Origin""*");</span>  
上面这句话的作用是:Access-Control-Allow-Origin 的值可以是通配符 *

如果是 * 的话,就可以接收来自任意source origin的请求,此时外部的任何js请求都被允许,缺少这句话则没有结果.

[java] view plaincopyprint?
  1. <%@ page language="java" import="java.util.*,java.sql.*,<span style="color:#CC0000;">org.json.*</span>"  
  2.     pageEncoding="utf-8"%>  
  3. <%  
  4.     <span style="color:#CC0000;">response.setHeader("Access-Control-Allow-Origin""*");</span>//注意这句话控制js访问权限  
  5.     String path = request.getContextPath();  
  6.     String basePath = request.getScheme() + "://"  
  7.             + request.getServerName() + ":" + request.getServerPort()  
  8.             + path + "/";  
  9. %>  
  10. <%  
  11.     String url = "jdbc:mysql://localhost:3306/jquery";  
  12.     String user = "root";  
  13.     String pass = "root";  
  14.     Connection conn = null;  
  15.     PreparedStatement pstmt = null;  
  16.     ResultSet rs = null;  
  17.     try {  
  18.         Class.forName("com.mysql.jdbc.Driver");  
  19.         conn = DriverManager.getConnection(url, user, pass);  
  20.         String sql = "select uid,username,imgurl,age from test1";  
  21.         pstmt = conn.prepareStatement(sql);  
  22.         rs = pstmt.executeQuery();  
  23.         // json数组  
  24.         JSONArray array = new JSONArray();  
  25.         // 获取列数  
  26.         ResultSetMetaData metaData = rs.getMetaData();  
  27.         int columnCount = metaData.getColumnCount();  
  28.         // 遍历ResultSet中的每条数据  
  29.         while (rs.next()) {  
  30.             JSONObject jsonObj = new JSONObject();  
  31.             // 遍历每一列  
  32.             for (int i = 1; i <= columnCount; i++) {  
  33.                 String columnName = metaData.getColumnLabel(i);  
  34.                 String value = rs.getString(columnName);  
  35.                 jsonObj.put(columnName, value);  
  36.             }  
  37.             array.put(jsonObj);  
  38.         }  
  39.         System.out  
  40.                 .println("======================返回的是json对象转化成的字符串==================");  
  41.         System.out.println(array.toString());  
  42.         out.print(array.toString());  
  43.     } catch (Exception e) {  
  44.         e.printStackTrace();  
  45.     }  
  46. %>  
数据库部分截图:

0 0
原创粉丝点击