中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript的Ajax封裝GET和POST

發布時間:2020-07-06 22:26:12 來源:網絡 閱讀:628 作者:瓶子小 欄目:web開發
<!DOCTYPE html>
<html>
<head>
    <title>封裝ajax</title>
</head>
<body>
<script type="text/javascript">

    function createXHR()
    {
        if(typeof XMLHttpRequest != "undefined")
        {
            return new XMLHttpRequest();
        }
        else if(typeof ActiveXObject != "undefined")
        {
            var versions = [
                "MSXML.2.XMLHttp.6.0",
                "MSXML.2.XMLHttp.3.0",
                "MSXML.2.XMLHttp"
            ];
            for(var i = 0; i<versions.length;i++)
            {
                try{
                    return new ActiveXObject(version[i]);
                }catch(e){
                    // 因類循環會報一個錯,跳過些錯
                }
            }
        }
        else
        {
            throw new Error("你的系統或瀏覽器不支持XHR對象!");
        }
    }

    // 名值對轉換字符串
    function params(data)
    {
        var arr = [];
        for(var i in data)
        {
            arr.push(encodeURIComponent(i)+"="+encodeURIComponent(data[i]));    
        }
        return arr.join("&");
    }

    // ajax 

    function ajax(obj)
    {
        var xhr=createXHR();
        obj.url=obj.url+"?rand="+Math.random();
        obj.data = params(obj.data);
        if(obj.method === "GET")
        {
            obj.url+=obj.url.indexOf("?") == -1 ?"?"+ obj.data:"&"+obj.data;    
        }

        //  if it's asynchronous
        if(obj.async === true)
        {
            xhr.onreadystatechange = function()
            {
                if(xhr.readyState == 4)
                {                   
                    callback();
                }
            }
        }
        xhr.open(obj.method,obj.url,obj.async);
        if(obj.method === "POST")
        {
            xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
            xhr.send(obj.data);
        }
        else
        {
            xhr.send(null);
        }       

        // iF It's synchronization
        if(obj.async === false)
        {
            callback();
        }

        // 封裝重復調用代碼
        function callback()
        {
            if(xhr.status === 200)
            {
                obj.success(xhr.responseText);
            }
            else
            {
                alert("錯誤代碼:"+xhr.status+"-錯誤信息:"+xhr.statusText);
            }
        }
    }

    //  use ajax

    addEventListener("click",function(){
        ajax({
            method:"POST",
            url:"test.php",
            data:{
                "na&me":"ping",
                "age":18
            },  
            // 將對象傳到text,然后對象又回調
            success:function(text)
            {
                console.log("接收success數據為:"+text);
            },
            async:false
        });
    },false);
</script>
</body>
</html>
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

敦煌市| 梓潼县| 宜川县| 彭水| 咸阳市| 蒙自县| 琼海市| 安仁县| 土默特左旗| 兴海县| 海安县| 昌江| 图们市| 襄城县| 寿宁县| 重庆市| 邹城市| 郑州市| 边坝县| 临夏市| 盐城市| 寻乌县| 东阿县| 开阳县| 德江县| 瓮安县| 拜城县| 渝中区| 比如县| 当阳市| 富阳市| 花莲县| 阿坝县| 平远县| 四平市| 香河县| 大方县| 济宁市| 黔南| 电白县| 虎林市|