jq 封装ajax,原生js Ajax封装、JQ中的Ajax

原生Ajax封装

/**

* 发送一个 AJAX 请求

* @param {String} method 请求方法

* @param {String} url 请求地址

* @param {Object} params 请求参数

* @param {Function} done 请求完成过后需要做的事情(委托/回调)

*/

function ajax (method, url, params, done) {

// 统一转换为大写便于后续判断

method = method.toUpperCase()

// 对象形式的参数转换为 urlencoded 格式

var pairs = []

for (var key in params) {

pairs.push(key + '=' + params[key])

}

var querystring = pairs.join('&')

var xhr = window.XMLHttpRequest ? new XMLHttpRequest() : new

ActiveXObject('Microsoft.XMLHTTP')

xhr.addEventListener('readystatechange', function () {

if (this.readyState !== 4) return

// 尝试通过 JSON 格式解析响应体

try {

done(JSON.parse(this.responseText))

} catch (e) {

done(this.responseText)

}

})

// 如果是 GET 请求就设置 URL 地址 问号参数

if (method === 'GET') {

url += '?' + querystring

}

xhr.open(method, url)

// 如果是 POST 请求就设置请求体

var data = null

if (method === 'POST') {

xhr.setRequestHeader('Content‐Type', 'application/x‐www‐form‐urlencoded')

data = querystring

}

xhr.send(data)

}

ajax('get', './get.php', { id: 123 }, function (data) {

console.log(data)

})

ajax('post', './post.php', { foo: 'posted data' }, function (data) {

console.log(data)

})

jQuery 中的 AJAX

jQuery 中有一套专门针对 AJAX 的封装,功能十分完善,经常使用,需要着重注意。

91b82fb1ad4a

$.ajax

$.ajax({

url: './get.php',

type: 'get',

dataType: 'json',

data: { id: 1 },

beforeSend: function (xhr) {

console.log('before send')

},

success: function (data) {

console.log(data)

},

error: function (err) {

console.log(err)

},

complete: function () {

console.log('request completed')

}

})

91b82fb1ad4a

详细可查看大佬的相关文章快速上手Ajax

来源于CSDN大佬的原创文章 地址:Poetic Code

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值