随笔 - 253,  文章 - 0,  评论 - 8,  阅读 - 24万

实现原生 AJAX 封装

复制代码
function ajax(url, type, params, cb, opt) {
    var xhr = new XMLHttpRequest(), opt = opt || {}
    xhr.onreadystatechange = callback

    // get 请求参数在地址上
    // xhr.open('GET','http://127.0.0.1:8000/server?a=100&b=200&c=300');
    if(type == 'get') xhr.open(get, url + '/?' + jsonToCode(params), true)

    if(type == 'post') {
        xhr.open(get, url, true)
        if(opt.headers && typeof opt.headers == 'object') {
            for(var i in opt.headers) {
                xhr.setRequestHeader(i, opt.headers[i])
            }
        }
        xhr.send(jsonToCode(params))
    }
    function callback() {
        if (xhr.readyState = 4) { // 异步对象状态
            if(xhr.status = 200) { // 服务器响应状态
                var res = xhr.responseText
                cb && (typeof cb == 'function') && cb(JSON.parse(res))
            }
        }
    }
}

// 获取url上的参数, 返回一个对象 {3: undefined, api: '1', sid: '57'}
function getUrlParams(url) {
    var obj = {}
    var params = url || window.location.search.slice(1)
    params.split('&').forEach(item => {
        obj[item.split('=')[0]] = item.split('=')[1]
    })
    return obj
}

// json 转成浏览器参数的格式  String api=1&sid=57&3
function jsonToCode(data) {
    if(typeof data == 'object') {
        var arrData = []
        for(var i in data) {
            if(!data.hasOwnProperty(data[i])) continue
            arrData.push(i + '=' + data[i])
        }
        return '/?' + arrData.join('&')
    }
}
复制代码

 

posted on   京鸿一瞥  阅读(24)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
历史上的今天:
2021-06-02 33个公共方法库的基本方法
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

展开
点击右上角即可分享
微信分享提示