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

本文详细介绍了如何在Node.js服务器(server.js)中处理AJAX请求,包括设置跨域、防止重复发送、以及特殊场景如IE缓存和延迟响应。重点讲解了取消请求的方法,并提供了一个HTML示例来演示如何使用JavaScript控制AJAX请求的发送和取消。
摘要由CSDN通过智能技术生成

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>

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值