jQuery入門[5]-AJAX

作者: Think  來源: 博客園  發布時間: 2009-12-20 20:52  閱讀: 3509 次  推薦: 1   原文鏈接   [收藏]  

jQuery為AJAX提供了非常豐富的支持,參見Ajax
其中最基本當屬$ajax(),通過不同的參數,這個方法可以錄活支持各種AJAX應用場景。如:

 
 
$.ajax({
url: "test.html",
cache: false,
success: function(html){
$("#results").append(html);
}
});

 


完整參數列表參見:options
當然,常用的應該是這些:
  • load()--直接將AJAX請求結果作為jQuery對象內容
  • $.get()--用get方式請求
  • $.post()--用post方式提交
  • ajaxStart()/ajaxComplete()/ajaxError()……--全局的ajax事件響應

DEMO:
建一個GenericHandler作AJAX請求服務端:CubeHandler.ashx

<%@ WebHandler Language="C#" Class="CubeHandler" %>

using System;
using System.Web;

public class CubeHandler : IHttpHandler {
    
    
public void ProcessRequest (HttpContext context) {
        context.Response.ContentType 
= "text/plain";
        
int number = 0;
        
int.TryParse(context.Request.Params["number"], out number);
        context.Response.StatusCode 
= 200;
        context.Response.Cache.SetCacheability(HttpCacheability.NoCache);
        context.Response.Write(
string.Format("{0} cubed is {1}",number,Math.Pow(number, 3)));
    }
 
    
public bool IsReusable {
        
get {
            
return true;
        }
    }
}

因為用的是Request.Params,所以這個handler能同時支持get和post,

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>ajaxtitle>
    <script src="../scripts/jquery-1.2.3.intellisense.js" type="text/javascript">script>
    <script type="text/javascript">
        $(function(){
            
//設置指示器
            $('#divIndicator').ajaxStart(function(){$(this).show()})
                            .ajaxSuccess(
function(){$(this).hide()})
                            .ajaxError(
function(msg){$(this).hide();alert(msg);});
            
//ajax get 請求
            $('#btnGetCubeInGet').click(function(){
                
var number = $('#txtNumber').val();
                $.get(
'CubeHandler.ashx?number='+number,function(result){
                    alert(result);
                });
            });
            
            
//ajax post 提交
            $('#btnGetCubeInPost').click(function(){
                
var number = $('#txtNumber').val();
                $.get(
'CubeHandler.ashx',{'number':number},function(result){
                    alert(result);
                });
            });
        });
    
script>
    <style type="text/css">
        .indicator
        
{
            color: #FF0000;
            position: absolute;
            top: 0px;
            right: 0px;
            display: none;
        }
    style>
head>
<body>
    <div id="divIndicator" class="indicator">
        <img src="indicator.gif" />loadingdiv>
    plz input a number:<input id="txtNumber" />
    <input type="button" id="btnGetCubeInGet" value="Get cube(get)" />
    <input type="button" id="btnGetCubeInPost" value="Get cube(post)" />
body>
html>


點擊按鈕后的效果:

1
0
 
標簽:jQuery
 
 

文章列表

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()