首頁 > web前端 > js教程 > jQuery中$.get、$.post、$.getJSON和$.ajax的用法

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

巴扎黑
發布: 2017-07-03 09:41:20
原創
1265 人瀏覽過


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:     》       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',   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);

         },

               alert(e );

        },

#        beforeSend: function(){

 //送出請求前呼叫,可以放一些正在載入"

            alert("載入中");        

#}})

#Oh

#a,以上就是為jquery實現了幾種,現在我把我最近新的一個小例子貼上來,這樣更直觀。

前台接收頁面:

注意要引入jquery mobile 套件

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title><script type ="text/javascript" src = "jquery-1.6.4.min.js"></script></head>
<script type = "text/javascript">
	$(function(){
		$("#button1").click(function(){
			//用getJSON方法获取后台传递过来的JSON对象数组			$.getJSON("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字符串,注意是字符串			$.get("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字符串,注意是字符串			$.post("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字符串			$.ajax({
				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>
登入後複製

後台2.jsp頁面:(這裡主要是測試前台接收json資料的幾種方式,故後台沒有分離,很簡陋)

注意要引入org.json套件




#

<%@ page language="java" import="java.util.*,java.sql.*,org.json.*"	pageEncoding="utf-8"%>
登入後複製
response.setHeader("Access-Control-Allow-Origin", "*");
登入後複製

上面這句話的作用是:Access-Control-Allow-Origin 的值可以是

通配符### *######如果是* 的話,就可以接收來自任意source origin的請求,此時外部的任何js請求都被允許,缺少這句話則沒有結果.##########
<%@ page language="java" import="java.util.*,java.sql.*,org.json.*"
	pageEncoding="utf-8"%>
<%	response.setHeader("Access-Control-Allow-Origin", "*");//注意这句话控制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的用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板