在 a 标签在本页面跳转到本页面之前做埋点发送,发现 ajax 发送不出去,后来发现是 click 事件到跳转事件发生的时间间距特别小,零点几毫秒,所以 click 之后发送的 ajax 事件会被拦截抛弃掉,但是我写了个小 demo 测试下,突然发现 demo 里面的 ajax 居然能发送出去。所以我就有点迷了,到底是怎么回事呢???
<a href="https://www.baidu.com/" id="hand">点我跳转</a>
let hand = document.getElementById('hand')
hand.addEventListener('click', () => {
ajax(url)
})
function ajax(url) {
let xhr = new XMLHttpRequest()
xhr.open("GET", url, true)
return new Promise((res, rej) => {
xhr.onload = function () {
xhr.status < 300 ? res() : rej()
}
xhr.send()
})
}
1
seki 2020-12-06 03:44:24 +08:00
页面跳转和发请求是两个并行的事情,谁先谁后都是有可能的
这种情况就需要找一个不被页面跳转销毁的地方暂存一下数据,比如如果跳转过去的是自家页面的话,用 session storage 之类的 |
3
Ptu2sha 2020-12-06 10:04:46 +08:00
看看人家访问系统怎么写的
|
4
des 2020-12-06 11:09:27 +08:00
|
6
ivank 2020-12-06 13:42:45 +08:00 via iPhone
你代码里面做成了 promise 版本的肯定可以啊 请求发送成功后才跳转的 跳转肯定有延迟感,不过你可以了解下 sendBeacon
|