BUappend
V2EX  ›  问与答

请教, a 标签在本标签页面切换之前做埋点

  •  
  •   BUappend · Dec 6, 2020 · 2525 views
    This topic created in 2012 days ago, the information mentioned may be changed or developed.

    在 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()
           })
    }
    
    Supplement 1  ·  Dec 6, 2020
    忘了一个事,是火狐才被 abort,chrome 是可以的
    6 replies    2020-12-06 13:42:45 +08:00
    seki
        1
    seki  
       Dec 6, 2020
    页面跳转和发请求是两个并行的事情,谁先谁后都是有可能的

    这种情况就需要找一个不被页面跳转销毁的地方暂存一下数据,比如如果跳转过去的是自家页面的话,用 session storage 之类的
    BUappend
        2
    BUappend  
    OP
       Dec 6, 2020 via Android
    @seki 为啥我写的这个能发出去呢
    Ptu2sha
        3
    Ptu2sha  
       Dec 6, 2020
    看看人家访问系统怎么写的
    des
        4
    des  
       Dec 6, 2020
    BUappend
        5
    BUappend  
    OP
       Dec 6, 2020
    @des 感谢,但是这个 IE 和 safari 不支持呀
    ivank
        6
    ivank  
       Dec 6, 2020 via iPhone
    你代码里面做成了 promise 版本的肯定可以啊 请求发送成功后才跳转的 跳转肯定有延迟感,不过你可以了解下 sendBeacon
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5346 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 42ms · UTC 08:47 · PVG 16:47 · LAX 01:47 · JFK 04:47
    ♥ Do have faith in what you're doing.