jQuery Ajax應用與常用外掛

布still發表於2017-08-18

jQuery 實現Ajax應用

使用load()方法非同步請求資料

使用load()方法通過Ajax請求載入伺服器中的資料,並把返回的資料放置到指定的元素中,它的呼叫格式為:

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

引數url為載入伺服器地址,可選項data引數為請求時傳送的資料,callback引數為資料請求成功後,執行的回撥函式

使用getJSON()方法非同步載入JSON格式資料

使用getJSON()方法可以通過Ajax非同步請求的方式,獲取伺服器中的資料,並對獲取的資料進行解析,顯示在頁面中,它的呼叫格式為:

jQuery.getJSON(url,[data],[callback])或$.getJSON(url,[data],[callback])

其中,url引數為請求載入json格式檔案的伺服器地址,可選項data引數為請求時傳送的資料,callback引數為資料請求成功後,執行的回撥函式

使用getScript()方法非同步載入並執行js檔案

使用getScript()方法非同步請求並執行伺服器中的JavaScript格式的檔案,它的呼叫格式如下所示:

jQuery.getScript(url,[callback])或$.getScript(url,[callback])

引數url為伺服器請求地址,可選項callback引數為請求成功後執行的回撥函式

使用get()方法以GET方式從伺服器獲取資料

使用get()方法時,採用GET方式向伺服器請求資料,並通過方法中回撥函式的引數返回請求的資料,它的呼叫格式如下:

$.get(url,[callback])

引數url為伺服器請求地址,可選項callback引數為請求成功後執行的回撥函式

使用post()方法以POST方式從伺服器傳送資料

post()方法用於以POST方式向伺服器傳送資料,伺服器接收到資料之後,進行處理,並將處理結果返回頁面,呼叫格式如下:

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

引數url為伺服器請求地址,可選項data為向伺服器請求時傳送的資料,可選項callback引數為請求成功後執行的回撥函式

使用serialize()方法序列化表單元素值

使用serialize()方法可以將表單中有name屬性的元素值進行序列化,生成標準URL編碼文字字串,直接可用於ajax請求,它的呼叫格式如下:

$(selector).serialize()

其中selector引數是一個或多個表單中的元素或表單元素本身

使用ajax()方法載入伺服器資料

使用ajax()方法是最底層、功能最強大的請求伺服器資料的方法,它不僅可以獲取伺服器返回的資料,還能向伺服器傳送請求並傳遞數值,它的呼叫格式如下:

jQuery.ajax([settings])或$.ajax([settings])

其中引數settings為傳送ajax請求時的配置物件,在該物件中,url表示伺服器請求的路徑,data為請求時傳遞的資料,dataType為伺服器返回的資料型別,success為請求成功的執行的回撥函式,type為傳送資料請求的方式,預設為get

<!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>使用ajax()方法載入伺服器資料</title>
        <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js" type="text/javascript"></script>
        <link href="style.css" rel="stylesheet" type="text/css" />
    </head>
    
    <body>
        <div id="divtest">
            <div class="title">
                <span class="fl">檢測數字的奇偶性</span> 
                <span class="fr">
                    <input id="btnCheck" type="button" value="檢測" />
                </span>
            </div>
            <ul>
               <li>請求輸入一個數字 
                   <input id="txtNumber" type="text" size="12" />
               </li>
            </ul>
        </div>
        
        <script type="text/javascript">
            $(function () {
                $("#btnCheck").bind("click", function () {
                    $.ajax({
                        url: "http://www.imooc.com/data/check.php",
                        data: { num: $("#txtNumber").val() },
                        type: `POST`,
                        success: function (data) {
                            $("ul").append("<li>你輸入的<b>  "
                            + $("#txtNumber").val() + " </b>是<b> "
                            + data + " </b></li>");
                        }
                    });
                })
            });
        </script>
    </body>
</html>

使用ajaxSetup()方法設定全域性Ajax預設選項

使用ajaxSetup()方法可以設定Ajax請求的一些全域性性選項值,設定完成後,後面的Ajax請求將不需要再新增這些選項值,它的呼叫格式為:

jQuery.ajaxSetup([options])或$.ajaxSetup([options])

可選項options引數為一個物件,通過該物件設定Ajax請求時的全域性選項值

<script type="text/javascript">
    $(function () {
        $.ajaxSetup({
            type:"post",
            dataType:"text",
            success:function(data){
                $("ul").append("<li>你輸入的<b>  "
                + $("#txtNumber").val() + " </b>是<b> "
                + data + " </b></li>");
            }
        });
        $("#btnShow_1").bind("click", function () {
            $.ajax({
                data: { num: $("#txtNumber").val() },
                url: "http://www.imooc.com/data/check.php"
            });
        })
        $("#btnShow_2").bind("click", function () {
            $.ajax({
                data: { num: $("#txtNumber").val() },
                url: "http://www.imooc.com/data/check_f.php"
            });
        })
    });
</script>

使用ajaxStart()和ajaxStop()方法

ajaxStart()和ajaxStop()方法是繫結Ajax事件。ajaxStart()方法用於在Ajax請求發出前觸發函式,ajaxStop()方法用於在Ajax請求完成後觸發函式。它們的呼叫格式為:

$(selector).ajaxStart(function())和$(selector).ajaxStop(function())

其中,兩個方法中括號都是繫結的函式,當傳送Ajax請求前執行ajaxStart()方法繫結的函式,請求成功後,執行ajaxStop ()方法繫結的函式

jQuery 常用外掛

表單驗證外掛——validate

該外掛自帶包含必填、數字、URL在內容的驗證規則,即時顯示異常資訊,此外,還允許自定義驗證規則,外掛呼叫方法如下:

$(form).validate({options})

其中form參數列示表單元素名稱,options參數列示呼叫方法時的配置物件,所有的驗證規則和異常資訊顯示的位置都在該物件中進行設定

<script type="text/javascript">
    $(function () {
        $("#frmV").validate(
            {
                /*自定義驗證規則*/
                rules: {
                    email: {
                        required: true,
                        email: true
                        }
                    },
                /*錯誤提示位置*/
                errorPlacement: function (error, element) {
                    error.appendTo(".tip");
                }
            }
        );
    });
</script>

表單外掛——form

通過表單form外掛,呼叫ajaxForm()方法,實現ajax方式向伺服器提交表單資料,並通過方法中的options物件獲取伺服器返回資料,呼叫格式如下:

$(form). ajaxForm ({options})

其中form參數列示表單元素名稱;options是一個配置物件,用於在傳送ajax請求過程,設定傳送時的資料和引數

<script type="text/javascript">
    $(function () {
        var options = {
        url: "http://www.imooc.com/data/form_f.php", 
        target: ".tip"
        }
        $(#frmV).ajaxForm(options);
    });
</script>

圖片燈箱外掛——lightBox

該外掛可以用圓角的方式展示選擇中的圖片,使用按鈕檢視上下張圖片,在載入圖片時自帶進度條,還能以自動播放的方式瀏覽圖片,呼叫格式如下:

$(linkimage).lightBox({options})

其中linkimage引數為包含圖片的<a>元素名稱,options為外掛方法的配置物件

圖片放大鏡外掛——jqzoom

在呼叫jqzoom圖片放大鏡外掛時,需要準備一大一小兩張一樣的圖片,在頁面中顯示小圖片,當滑鼠在小圖片中移動時,呼叫該外掛的jqzoom()方法,顯示與小圖片相同的大圖片區域,從而實現放大鏡的效果,呼叫格式如下:

$(linkimage).jqzoom({options})

其中linkimage引數為包含圖片的<a>元素名稱,options為外掛方法的配置物件

<script type="text/javascript">
    $(function () {
        $("#jqzoom").jqzoom({ //繫結圖片放大外掛jqzoom
            zoomWidth: 123, //小圖片所選區域的寬
            zoomHeight: 123, //小圖片所選區域的高
            zoomType: `reverse` //設定放大鏡的型別
        });
    });
</script>

cookie外掛——cookie

使用cookie外掛後,可以很方便地通過cookie物件儲存、讀取、刪除使用者的資訊,還能通過cookie外掛儲存使用者的瀏覽記錄,它的呼叫格式為:

儲存:$.cookie(key,value);讀取:$.cookie(key),刪除:$.cookie(key,null)

其中引數key為儲存cookie物件的名稱,value為名稱對應的cookie值

<script type="text/javascript">
    $(function () {
        if ($.cookie("email")) {
            $("#email").val($.cookie("email"));
        }
        $("#btnSet").bind("click", function () {
            if ($("#chksave").is(":checked")) {
                $.cookie("email", $("email").val(), {
                    path: "/", expires: 7
                })
            }
            else {
                $.cookie("email", null, {
                    path: "/"
                })
            }
        });
    });
</script>

搜尋外掛——autocomplete

搜尋外掛的功能是通過外掛的autocomplete()方法與文字框相繫結,當文字框輸入字元時,繫結後的外掛將返回與字元相近的字串提示選擇,呼叫格式如下:

$(textbox).autocomplete(urlData,[options]);

其中,textbox引數為文字框元素名稱,urlData為外掛返回的相近字串資料,可選項引數options為呼叫外掛方法時的配置物件

<body>
    <div id="divtest">
        <div class="title">
            <span class="fl">搜尋外掛</span>
        </div>
        <div class="content">
            <span class="fl">使用者名稱</span><br />
            <input id="txtSearch" name="txtSearch" type="text" />
            <div class="tip">
            </div>
        </div>
    </div>
    
    <script type="text/javascript">
        $(function () {
            var arrUserName = ["王五", "劉明", "李小四", "劉促明", "李淵", "張小三", "王小明"];
            $("#txtSearch").autocomplete(arrUserName, {
                minChars: 0, //雙擊空白文字框時顯示全部提示資料
                formatItem: function (data, i, total) {
                    return "<I>" + data[0] + "</I>"; //改變匹配資料顯示的格式
                },
                formatMatch: function (data, i, total) {
                    return data[0];
                },
                formatResult: function (data) {
                    return data[0];
                }
            }).result(SearchCallback); 
            function SearchCallback(event, data, formatted) {
                $(".tip").show().html("您的選擇是:" + (!data ? "空" : formatted));
            }
        });
    </script>
</body>

右鍵選單外掛——contextmenu

右鍵選單外掛可以繫結頁面中的任意元素,繫結後,選中元素,點選右鍵,便通過該外掛彈出一個快捷選單,點選選單各項名稱執行相應操作,呼叫程式碼如下:

$(selector).contextMenu(menuId,{options});

Selector引數為繫結外掛的元素,meunId為快捷選單元素,options為配置物件

<body>
    <div id="divtest">
        <div class="title"><span class="fl">點選右鍵</span></div>
        <div class="content">
            <input id="btnSubmit" type="button" value="提交" />
            <div class="tip"></div>
        </div>
        <div class="contextMenu" id="sysMenu">
            <ul>
                <li id="Li3"><img src="http://img.mukewang.com/52e4b34b0001bb6d00160016.jpg" alt="" />儲存</li>
                <li id="Li4"><img src="http://img.mukewang.com/52e4b3680001424900160016.jpg" alt="" />退出</li>
            </ul>
        </div>
    </div>
    
    <script type="text/javascript">
        $(function () {
            $("#divtest").contextMenu(`sysMenu`,
              { bindings:
                 {
                     `Li3`: function (Item) {
                         $(".tip").show().html("您點選了“儲存”項");
                     },
                     `Li4`: function (Item) {
                         $(".tip").show().html("您點選了“退出”項");
                     }
                 }
              });
        });
    </script>
</body>

自定義物件級外掛——lifocuscolor外掛

自定義的lifocuscolor外掛可以在<ul>元素中,滑鼠在表項<li>元素移動時,自定義其獲取焦點時的背景色,即定義<li>元素選中時的背景色,呼叫格式為:

$(Id).focusColor(color)

其中,引數Id表示<ul>元素的Id號,color表示<li>元素選中時的背景色

<body>
    <div id="divtest">
        <div class="title">
            <span class="fl">物件級別的外掛</span>
        </div>
        <div class="content">
            <ul id="u1">
                <li><span>橘子</span><span>水果</span></li>
                <li><span>芹菜</span><span>蔬菜</span></li>
                <li><span>香蕉</span><span>水果</span></li>
            </ul>
        </div>
    </div>
    
    <script type="text/javascript">
        $(function () {
            $("#u1").focusColor("#888"); //呼叫自定義的外掛
        })
    </script>
</body>

自定義類級別外掛—— twoaddresult

通過呼叫自定義外掛twoaddresult中的不同方法,可以實現對兩個數值進行相加和相減的運算,匯入外掛後,呼叫格式分別為:

$.addNum(p1,p2) 和 $.subNum(p1,p2)

上述呼叫格式分別為計算兩數值相加和相減的結果,p1和p2為任意數值

<body>
    <div id="divtest">
        <div class="title">
            <span class="fl">自定義類級別外掛</span> 
            <span class="fr">
                <input id="btnCount" type="button" value="計算" />
            </span>
        </div>
        <div class="content">
            兩數相減:
            <input id="Text1" type="text" class="txt" />
            -
            <input id="Text2" type="text" class="txt" />
            =
            <input id="Text3" type="text" class="txt" />
        </div>
    </div>
    
    <script type="text/javascript">
        $(function () {
            $("#btnCount").bind("click", function () {
                $("#Text3").val(
                    $.subNum($("#Text1").val(),
                        $("#Text2").val())
                );
            });
        });
    </script>
</body>

相關文章