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>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
- <title>Insert title here</title>
- <span style="color:#CC0000;"><script type ="text/javascript" src = "jquery-1.6.4.min.js"></script></span>
- </head>
- <script type = "text/javascript">
- $(function(){
- $("#button1").click(function(){
- //用getJSON方法获取后台传递过来的JSON对象数组
- <span style="color:#CC0000;">$.getJSON</span>("http://10.65.9.181:8090/jq_test_server/2.jsp",function(data){
- //调用each方法进行数组遍历
- $.each(data,function(index,item){
- //alert(data);
- //alert(item.username); 依次打印所有的username
- //alert(item);
- //打印出遍历的username的最后一个,因为之前的username会被后者覆盖//打印zxy
- $("#button1").html(item.username);
- });
- });
- });
- $("#button2").click(function(){
- //用get方法获取后台传递过来的json字符串,注意是字符串
- <span style="color:#CC0000;">$.get</span>("http://10.65.9.181:8090/jq_test_server/2.jsp",function(data){
- //alert(data);
- //将字符串转化为json对象
- data = JSON.parse(data);
- $("#button2").html(data[1].username);
- });
- });
- $("#button3").click(function(){
- //用post方法获取后台传递过来的json字符串,注意是字符串
- <span style="color:#CC0000;">$.post</span>("http://10.65.9.181:8090/jq_test_server/2.jsp",function(data){
- //alert(data);
- //将字符串转化为json对象
- data = JSON.parse(data);
- $("#button3").html(data[1].username);
- });
- });
- $("#button4").click(function(){
- //采用ajax方式获取json字符串
- <span style="color:#CC0000;">$.ajax</span>({
- type:"GET",
- url:"http://10.65.9.181:8090/jq_test_server/2.jsp",
- success:function(data){
- //强制转换为json对象
- data = JSON.parse(data);
- //打印的是对象数组里面的第一个值对应的username
- $("#button4").html(data[0].username);
- }
- });
- });
- });
- </script>
- <body>
- <a id = "button1" href = "#">getJSON方法</a>
- <a id = "button2" href = "#">get方法</a>
- <a id = "button3" href = "#">post方法</a>
- <a id = "button4" href = "#">ajax方法</a>
- </body>
- </html>
注意要引入org.json包
- <span style="color:#000000;"><%@ page language="java" import="java.util.*,java.sql.*</span>,<span style="color:#CC0000;">org.json.*</span>"
- <span style="color:#000000;">pageEncoding="utf-8"%></span>
- <span style="color:#CC0000;">response.setHeader("Access-Control-Allow-Origin", "*");</span>
如果是 * 的话,就可以接收来自任意source origin的请求,此时外部的任何js请求都被允许,缺少这句话则没有结果.
- <%@ page language="java" import="java.util.*,java.sql.*,<span style="color:#CC0000;">org.json.*</span>"
- pageEncoding="utf-8"%>
- <%
- <span style="color:#CC0000;">response.setHeader("Access-Control-Allow-Origin", "*");</span>//注意这句话控制js访问权限
- String path = request.getContextPath();
- String basePath = request.getScheme() + "://"
- + request.getServerName() + ":" + request.getServerPort()
- + path + "/";
- %>
- <%
- String url = "jdbc:mysql://localhost:3306/jquery";
- String user = "root";
- String pass = "root";
- Connection conn = null;
- PreparedStatement pstmt = null;
- ResultSet rs = null;
- try {
- Class.forName("com.mysql.jdbc.Driver");
- conn = DriverManager.getConnection(url, user, pass);
- String sql = "select uid,username,imgurl,age from test1";
- pstmt = conn.prepareStatement(sql);
- rs = pstmt.executeQuery();
- // json数组
- JSONArray array = new JSONArray();
- // 获取列数
- ResultSetMetaData metaData = rs.getMetaData();
- int columnCount = metaData.getColumnCount();
- // 遍历ResultSet中的每条数据
- while (rs.next()) {
- JSONObject jsonObj = new JSONObject();
- // 遍历每一列
- for (int i = 1; i <= columnCount; i++) {
- String columnName = metaData.getColumnLabel(i);
- String value = rs.getString(columnName);
- jsonObj.put(columnName, value);
- }
- array.put(jsonObj);
- }
- System.out
- .println("======================返回的是json对象转化成的字符串==================");
- System.out.println(array.toString());
- out.print(array.toString());
- } catch (Exception e) {
- e.printStackTrace();
- }
- %>
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- 理解jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- JQuery中$.get、$.post、$.getJSON和$.ajax的用法
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法详解
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法详解
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法详解
- Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结
- Spark Getting started
- 第二十二次codeforces竞技结束 #278 Div 2
- The substring() Method in JDK 6 and JDK 7
- Script Control 组件Win7 X64平台运行问题及示例
- jQuery中$.get $.post $.getJSON $.ajax方法详解
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- ajax原生代码
- Spring Web应用的最大瑕疵
- Google Cloud Messaging (Android 消息推送技术) (一)
- java实现B-Tree
- java中的递归——成员变量,局部变量,静态变量
- $provider里factory、service方法
- 便于游戏开发的工具(自用,持续更新)
- 如何获取手机屏幕大小