ajax方法简单实现
ajax基本步骤
1. 判断方法类型,GET,POST或其他
2. 得到数据,&分隔的key value字符串形式
3. 注册onreadystatechange事件
4. 开启请求,调用open
5. 发送数据,调用send
ajax的过程状态
xhr.readystate
0 未初始化
1 请求开启,但未发送,open后send前
2 请求已发送,send后
3 响应头已接收,响应体未完成
4 响应全部接收
function ajax(options){ var xhr = window.XMLHttpRequest ? new XMLHttpRequest() : new ActiveXObject('...'); var {url,method,data,async,success,fail} = options; var sendBody = null; var qs = Object.keys(data).reduce(function(cur,pre,index){ return pre + '&' + encodeURIComponent(cur) + '=' + encodeURIComponent(data[cur]); },'').slice(1); if(medthod == 'get'){ url += '?' + qs; } else if(medhot == 'post'){ xhr.setRequestHeader('Content-type', 'application/x-www-form-urlencoded'); sendBody = qs || null; } xhr.onreadystatechange = function(){ if(xhr.readystate == 4){ if(xhr.status >= 200 && xhr.status < 300 || xhr.status == 304){ success && success(xhr.responseText); } } else{ fail && fail({ status:xhr.status, statusText:xhr.statusText }); } } xhr.open(method,url,async); xhr.send(sendBody); }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具