首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在Django web应用程序中减慢Vue.js更新方法中的请求速率

在Django web应用程序中减慢Vue.js更新方法中的请求速率
EN

Stack Overflow用户
提问于 2018-12-08 11:35:43
回答 1查看 176关注 0票数 0

我在Django模板中有一个Vue.js视图。Vue从Django Rest Framework端点提取要在视图中显示的数据。我的代码如下:

代码语言:javascript
运行
复制
    const app = new Vue({
        el: '#app',
        delimiters: ["[%", "%]"],
        data: {
            dedicated_server: [],
        },
        created() {
            fetch('/api/dedicated-server/{{ object.id }}/')
                .then(response => response.json())
                .then(json => {
                    this.dedicated_server = json;
                })
        },
        updated() {
            /* TODO: Try and limit the number of requests to the API */
            fetch('/api/dedicated-server/{{ object.id }}/')
                .then(response => response.json())
                .then(json => {
                    this.dedicated_server = json
                })
        },
    });

如您所见,我有一个更新的方法,它轮询Restful端点,以便在数据更改时更新页面。这一切都很好,但似乎每秒钟轮询Restful端点3至5次。这是很好的开发,但如果我有100人访问这个页面,那么它将杀死我的服务器与请求。

是否有办法限制Vue.js检查的次数,以查看数据是否已经更新?如果你能说每5秒检查一次,那就太好了。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-12-08 11:51:39

您可以使用setInterval每5秒运行一次。在created中设置它,您不需要担心updated

代码语言:javascript
运行
复制
    setInterval(() => 
        fetch('/api/dedicated-server/{{ object.id }}/')
            .then(response => response.json())
            .then(json => {
                this.dedicated_server = json;
            }),
        5000);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53682123

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档