Ajax的原理,以及如何实现

Ajax是什么

全称(Async Javascript and XML)即异步的JavaScript和XML

是一种异步请求数据的web开发技术,在不需要重新刷新页面的情况下,与服务器交换数据,并且更新部分网页

Ajax的原理

简单地来说通过XMLHttpRequest对象向服务器发起异步请求,从服务器获得数据,然后用JavaScript来操作DOM而更新页面

如何实现

  • 封装一个Ajax请求,传入参数

  • 创建XMLHttpRequest对象

  • 将请求的方式转换为大写并判断是get请求还是post请求

  • 如果是get请求,调用open函数,传入请求的方式以及请求的地址

  • 再调用send函数,发起请求

  • 如果是post请求和get的请求一样,多了一个 设置content-type的属性,这个是固定的

  • 最后监听返回的数据,并判断请求的参数是否等于4,以及响应的参数是否等于200,将响应回来的数据进行处理后返回

实现代码

function ajax(options) {
            // 1.创建xhr对象
            var xhr = new XMLHttpRequest()
            // 2.判断是get请求还是post请求 发起请求
            if (options.method.toUpperCase() === 'GET') {
                // GET请求 调用open函数发 传入请求方式以及请求地址
                xhr.open(options.method, options.url)
                // 调用send,发送请求
                xhr.send()
            } else {
                // POST请求 调用open函数 传入请求方式以及请求地址
                xhr.open(options.method, options.url)
                // 设置content-Type属性
                xhr.setRequestHeader(
                    'Content-Type',
                    'application/x-www-form-urlencoded'
                )
                // 调用send,发送请求
                xhr.send()
            }
            // 3.监听返回的数据
            xhr.onreadystatechange=function() {
                // 4.判断请求的状态以及响应的状态
                if(xhr.readyState===4&&xhr.status===200) {
                    // 5.将响应回来的数据进行处理后返回
                   options.success && options.success(JSON.parse(xhr.response))
                }
            }
        }

封装后的使用方式

ajax({
     type: 'post',
     dataType: 'json',
     data: {},
     url: 'https://xxxx',
     success: function(text,xml){//请求成功后的回调函数
         console.log(text)
     },
     fail: function(status){请求失败后的回调函数
         console.log(status)
     }
})

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C# AJAX(Asynchronous JavaScript and XML)是一种用于在应用程序中现异步通信的技术。它许在不刷新个页面的情况下,通过与服务器进行异步通信来更新部分页面内容。 C# AJAX的底层实现原理主要包括以下几个方面: 1. XMLHttpRequest对象:C# AJAX使用XML对象来实现与服务器的异步通信。该对象可以在后台与服务器进行数据交换,而不会干扰到页面的显示和行为。通过该对象,可以发送HTTP请求并收服务器返回的数据。 2. 事件驱动模型:C# AJAX使用事件驱动模型来处理步通信过程中的各种事件。例如,可以通过监听XMLHttpRequest对象的onreadystatechange事件来获取服务器返回的数据,并在数据返回后执行相应的操作。 3. 数据格式:C# AJAX通常使用JSON(JavaScript Object Notation)或XML(eXtensible Markup Language)格式来传输数据。JSON是一种轻量级的数据交换格式,易于解析和生成;而XML是一种通用的标记语言,具有良好的可扩展性。 4. 服务器端处理:在服务器端,C# AJAX通常使用ASP.NET Web API或ASP.NET MVC等技术来处理异步请求。服务器端会根据请求的类型和参数,执行相应的逻辑,并将结果返回给客户端。 总的来说,C# AJAX的底层实现原理是通过XMLHttpRequest对象实现与服务器的异步通信,并使用事件驱动模型处理通过程中的各种事件。同时,使用JSON或XML格式传输数据,并在服务器端使用应的技术进行处理
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值