【问题标题】:Express: why is this GET request executed twice?Express:为什么这个 GET 请求执行了两次?
【发布时间】:2015-05-16 23:01:42
【问题描述】:

我有一些用 Jade 编写的代码,里面有一个链接。链接的目的地由 Jade 生成。单击链接时,我从控制台注意到 GET 请求正在执行两次。

这是为什么?我该如何解决这个问题?

这是我的代码:

玉文件:

ul.media-list
    each paper in paperList
        div.panel.panel-default
            div.panel-body
                li.media
                    div.media-left.media-middle
                        a(href='/publication/view/#{paper.id}')
                            | Some image
                    div.media-body
                        div.btn-group(role='group')
                            //!!! When this link is being clicked, GET is executed twice !!!
                            a.btn.btn-default(href='/publication/view/#{paper.id}')
                                | View

控制台:

GET /publication/view/123 200 490ms - 5623
GET /publication/view/123 304 458ms - -

app.js:

var publication = require('./routes/publication');
app.use('/publication', publication);

publication.js:

var express = require('express');
var router = express.Router();

router.get('/view/:id', function (req, res) {
    var data;
    //Some database functions here
    //Just an example
    res.render('publication', {someData: data});
});

【问题讨论】:

  • media-left 和 media-body 是否以某种方式重叠?在这种情况下,两个链接都可能会触发点击事件。
  • 不,media-left 和 media-body 是 2 个独立的 div。我刚刚签入了生成的 HTML。
  • router 定义在哪里?
  • @ExplosionPills 查看我对publication.js的编辑
  • @JNevens 您可以使用一些虚拟 paper.id 执行 curl 请求 curl {baseURL}/publication/view/#{paper.id},以将问题缩小到前端或后端。还可以尝试记录request.url,在某些情况下会发出一个额外的请求来获取网站图标。

标签: javascript node.js http express pug


【解决方案1】:

这只是一个假设,但您的浏览器似乎正在使用某种预测算法来预加载您的链接,甚至在您点击它们之前。 Google Chrome do such things.

Express.js 以304 Not Modified 响应响应第二个响应,这表明它以有效的ETag 值发送以验证先前缓存的响应。

尝试在您的浏览器中禁用网络行为预测。以下是它在 Google Chrome 设置中的外观 (Settings -> Show advanced settings...):

或者,您可以尝试在实际点击链接之前验证第一个请求是否已发送,方法是将鼠标悬停在链接上,但不点击它。

【讨论】:

  • 我觉得这个选项现在可能叫“使用预测服务来更快地加载页面”?
【解决方案2】:

它的 Chrome 问题在 Firefox 或资源管理器中没有发生

【讨论】:

  • 请使用cmets提问
【解决方案3】:

我遇到了同样的问题。

我发送的 html 页面包含... -image width="50" height="50" src='不存在'-

cause -> get resource 将被调用两次。

如果 src="" 为空或 src="图像存在"

get 资源只会被调用一次... 所以在我的情况下,缺少图片网址会导致这个问题......

【讨论】:

  • 正如目前所写,您的答案尚不清楚。请edit 添加其他详细信息,以帮助其他人了解这如何解决所提出的问题。你可以找到更多关于如何写好答案的信息in the help center
猜你喜欢
  • 1970-01-01
  • 2020-04-20
  • 1970-01-01
  • 1970-01-01
  • 2013-03-08
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多