五、手动取消ajax请求 && 解决重复发送请求问题

server.js:

// 1. 引入express
const express = require('express')


// 2. 创建应用对象
const app = express()

// 3. 创建路由规则
app.get('/server', (request, response) => {
    
    
	// 设置响应头 设置允许跨域
	response.setHeader('Access-Control-Allow-Origin', '*')

	
	// 设置响应体
	response.send('hello ajax!!!')
})

 // all 可以接收任意类型的请求
app.all('/server', (request, response) => {
    
    
	// 设置响应头 设置允许跨域
	response.setHeader('Access-Control-Allow-Origin', '*')
	
	// 允许前端post请求 自定义请求头名称
	response.header('Access-Control-Allow-Headers', '*');
	
	// 设置响应体
	response.send('hello ajax post')
})

app.all('/json-server', (request, response) => {
    
    
	// 设置响应头 设置允许跨域
	response.setHeader('Access-Control-Allow-Origin', '*')
	
	// 允许前端post请求 自定义请求头名称
	response.header('Access-Control-Allow-Headers', '*');
	
	// 响应一个数据
	const data = {
    
    
		name: 'zep'
	};
	
	// 对 对象进行字符串转换
	let str = JSON.stringify(data)
	
	// 设置响应体,send方法只接收字符串类型的参数
	response.send(str)
})

// 专门针对IE缓存
app.get('/ie', (request, response) => {
    
    
	// 设置响应头 设置允许跨域
	response.setHeader('Access-Control-Allow-Origin', '*')

	
	// 设置响应体
	response.send('hello ie3!!!')
})

// 延时响应
app.get('/delay', (request, response) => {
    
    
	// 设置响应头 设置允许跨域
	response.setHeader('Access-Control-Allow-Origin', '*')
	// 设置定时器,当客户端发起请求时,服务端延迟3s再将响应数据发给客户端
	setTimeout(() => {
    
    
		// 设置响应体
		response.send('hello 延迟响应3秒!!!')
	}, 3000)
	
	
})


// 4. 监听端口 启动服务
app.listen(8000, () => {
    
    
	console.log('服务已经启动,8000端口监听中...')
})

1. 取消请求

在这里插入图片描述

2. 解决重复发送请求问题

增加一个标识变量 isSending

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>AJAX 重复请求 请求</title>
		<style type="text/css">
			#result {
     
     
				width: 200px;
				height: 100px;
				border: 1px solid pink;
			}
		</style>
	</head>
	<body>
		<button>点击发送请求</button>
		<button>点击取消请求</button>	
		<script>
			// 获取button元素
			const btns = document.querySelectorAll('button');
			
			let xhr = null;
			
			// 标识变量
			let isSending = false; // 是否正在发送AJAX请求
			
			// 绑定事件
			btns[0].onclick = function() {
     
     
				
				// 如果正在发送,则取消该请求,创建一个新的
				if(isSending) {
     
     
					xhr.abort();
				}
				
				// 1.创建对象
				xhr = new XMLHttpRequest();
				
				// 修改标识变量的值
				isSending = true;
				
				// 2.初始化 设置请求方法 和 url
				xhr.open('GET', 'http://127.0.0.1:8000/delay');
				// 3.发送
				xhr.send();
				// 4.事件绑定,处理服务端返回的结果
				xhr.onreadystatechange = function() {
     
     
					if(xhr.readyState === 4) {
     
     
						// 修改标识变量
						isSending = false;
					}
				}
			}
			
			btns[1].onclick = function () {
     
     
				// 取消请求
				xhr.abort()
			}
			
		</script>
		
	</body>
</html>

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_44827418/article/details/115176917