网页数据如何实现实时刷新?

网页数据如何实现实时刷新?本文仅为学技术而简单举例,后端框架是Django,具体业务逻辑是否合理可以不用管,下方是工作中需要实现的需求。

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

来源商业新知网,原标题:精讲网页数据实时刷新实现

本文仅为学技术而简单举例,后端框架是Django,具体业务逻辑是否合理可以不用管,下方是工作中需要实现的需求

自动化程序脚本运行的三种任务状态:

1、未执行  2、执行成功  3、执行失败

任务状态在网页前端实时展示,需要每隔一段时间请求数据库中的状态数据字段为webtask_stu,并返回前端展示

知识图谱,精讲网页数据实时刷新实现

两种思路:

1、前端轮询,每请求一次,建立一次连接,后端返回前端数据一次

具体实现:设置定时器,每隔5s请求后端数据,后端返回数据后渲染前端

2、前端请求只建立一次连接,后端能持续主动向前端推送数据

具体实现:前端通过socket方式向后端建立连接,后端定时查询数据库数据,主动向前端推送,这种优点很明显,可以减少网络请求次数

方式一:Ajax定时请求:

1、前端设置定时器setInterval,定时器里面传ajax请求函数和时间

function get_stu_list(){

 param = {}; $.post(“/web/webtask_stu/”,param,function(data){    var webtask_tu_list = data.webtask_stu;    console.log(webtask_tu_list);    var tr = $(“tbody tr”);   $.each(tr,function (i,ele) {      $(ele).find(“td:eq(4)”).text(webtask_tu_list[i])   });  });};setInterval(get_stu_list,5000);

后端也很简单,查询数据以JSonResponse返回即可

@csrf_exempt

def webtask_stu(request):  webtasks = Webtask.objects.all()  webtask_stu_list = []   for webtask in webtasks:    webtask_stu_list.append(webtask.webtask_stu)    dit = {‘webtask_stu’: webtask_stu_list}    print(webtask_stu_list)   return JsonResponse(dit)

方式二、websocket

效果图如下,后端持续向前端推送数据,前端控制台输出演示

知识图谱,精讲网页数据实时刷新实现

1、前端部分构造socket连接对象,协议就是websocket协议了,不是http协议,所以前面用ws开头

2、windows.loaction.host可以获取域名(包括端口)

3、主要用到的方法如下,具体也可以看注释

socket.onopen : 成功连接

socket.onmessage : 成功获取后端返回的数据,通过jquery渲染后端返回的状态数据实现刷新效果

socket.onclose:连接失效

4、后端返回来是字符串,需要用到JSON.parse转成前端对象

var socket = new WebSocket(“ws:” + window.location.host + “/web/webtask_stu/”);

socket.onopen = function () {    console.log(‘WebSocket open’);//成功连接上Websocket    socket.send(‘adasdasda。。。。’);//发送数据到服务端 }; socket.onmessage = function (e) {    // console.log(‘message: ‘ + e.data);//打印服务端返回的数据     // console.log(typeof (e.data));     console.log(JSON.parse(e.data));     // console.log(typeof (JSON.parse(e.data)));     var webtask_stu_list = JSON.parse(e.data);     var tr = $(“tbody tr”);    $.each(tr,function (i,ele) {      $(ele).find(“td:eq(4)”).text(webtask_stu_list[“webtask_stu”][i])    }); }; socket.onclose=function(e){  console.log(e); socket.close(); //关闭TCP连接 };

后端Django部分:

1、django项目的话安装dwebsocket,pip install dwebsocket ,并在代码中导入

from dwebsocket.decorators import accept_websocket

2、加装饰器@accept_websocket,接收socket请求

3、if request.is_websocket,判断是否是websocket请求是的话执行我们后端的从数据库查询数据的功能

4、通过time.sleep和while循环实现每隔5秒向前端发送数据

4、request.websocket.send(json数据)返回数据到前端,因为这里是json数据格式,所以前端上面要用JSON.parse转对象,

@accept_websocket

def webtask_stu(request):    if request.is_websocket():      while 1:       webtasks = Webtask.objects.all()       webtask_stu_list = []        for webtask in webtasks:         webtask_stu_list.append(webtask.webtask_stu)         dit = {‘webtask_stu’: webtask_stu_list}        time.sleep(5)       request.websocket.send(json.dumps(dit))

两种思路大致如上,实现socket还有其他更高级的api,有兴趣可以网上看看学习。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/166623.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • FastClick遇到的坑及解决办法

    FastClick遇到的坑及解决办法最近产品妹子提出了一个体验issue——用iOS在手Q阅读书友交流区发表书评时,光标点击总是不好定位到正确的位置:如上图,具体表现是较快点击时,光标总会跳到textarea内容的尾部。只有当点击停留时间较久一点(比如超过150ms)才能把光标正常定位到正确的位置。一开始我以为是iOS原生的交互问题没太在意,但后来发现访问某些页面又是没有这种奇怪体验的。然后怀疑是否…

  • 读完了csapp(中文名:深入理解计算机系统)

    读完了csapp(中文名:深入理解计算机系统)

  • 量子通讯加密技术的技术原理

    量子通讯加密技术的技术原理1什么是量子一个物理量如果存在最小的不可分割的基本单位,则这个物理量是量子化的,并把最小单位称为量子。量子英文名称量子一词来自拉丁语quantus,意为“有多少”,代表“相当数量的某物质”。在物理学中常用到量子的概念,指一个不可分割的基本个体。例如,“光的量子”(光子)是一定频率的光的基本能量单位。而延伸出的量子力学、量子光学等成为不同的专业研究领域。其基本概念为所有的有形性质是“可量子化的”。“

  • Java学习之JSP篇

    Java学习之JSP篇0x00前言关于jsp的内容其实不多,就来简单的记录一下jsp概念性的内容,避免忘记。0x01Jsp概念jsp的全称是JavaServerPages:java服

    2021年12月12日
  • 太极图正确画法_来氏太极图的画法及六行太极图的演示

    太极图正确画法_来氏太极图的画法及六行太极图的演示本来,我已打算停中发文,但是这一篇涉及到我一个重要的思想,这就是我对明代来知德的“来氏太极图”有了重要的理解,我根据它形成了我的六行太极理论,于是我还是决定把它公布出来。我尝试很多办法把水火金木土风的六行的元素融入到太极图中,它既要能符合太极的原理,又要能符合六行的原理,但又要使用它最简单化,可始终无果,有一天,我看到了明代理学家来知德的《来瞿唐先生圆图》,忽然恍然大悟,来瞿唐先生的“来氏太极图”…

  • 191. Number of 1 Bits Leetcode Python

    191. Number of 1 Bits Leetcode Python

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号