AJAX,即“Asynchronous JavaScript and XML”(异步JavaScript和XML),是指一种创建交互式、快速动态应用的技术。AJAX不是一种新的编程语言,而是一种用于创建更好更快用户体验的技术。
AJAX的交互流程通常包括以下几个步骤:
- 创建一个新的
XMLHttpRequest
对象(或者ActiveXObject对象,IE5、6)。 - 设置请求的参数,如请求方法、URL、是否异步等。
- 设置请求状态变化的回调函数。
- 发送请求。
- 接收响应数据。
跨域通常发生在当你的web应用尝试请求另一个域的资源时。出于安全考虑,浏览器默认限制跨域请求。解决跨域问题的方法有:
- JSONP:通过
<script>
标签的src
属性发送请求,服务器响应一个回调函数。 - CORS:服务器设置
Access-Control-Allow-Origin
响应头允许特定的域进行请求。 - 代理服务器:在服务器端设置代理,请求先发送到同源服务器,由服务器代理转发请求到目标域。
- 在客户端使用iframe和window.name实现跨域通信。
以下是一个简单的AJAX请求示例:
var xhr = new XMLHttpRequest();
xhr.open("GET", "https://api.example.com/data", true);
xhr.onreadystatechange = function() {
if (xhr.readyState == 4 && xhr.status == 200) {
var response = JSON.parse(xhr.responseText);
console.log(response);
}
};
xhr.send();
对于跨域请求,假设服务器已经设置了CORS,客户端代码不变,服务器需要在响应头中添加如下设置:
Access-Control-Allow-Origin: https://yourdomain.com
Access-Control-Allow-Methods: GET, POST, OPTIONS
以上代码展示了AJAX请求的基本流程以及简单的跨域解决方案。