《Web异步与实时交互——iframe AJAX WebSocket开发实战》—— 2.3 示例程序

简介:

本节书摘来异步社区《Web异步与实时交互——iframe AJAX WebSocket开发实战》一书中的第2章,第2.3节,作者: 赵振 , 王顺 , 于梦竹 , 李泽 , 侯法超 , 刘备 , 时国森 , 李照耀 , 王世军,更多章节内容可以访问云栖社区“异步社区”公众号查看。

2.3 示例程序

下面使用iframe模拟异步交互技术,使用轮询的方式,实现数字累加功能。

2.3.1 客户端关键代码
客户端代码主要包含3个部分:定时向服务器端发送请求、接收服务器端返回的信息及展示服务器端返回的信息。

关键代码如下所示:

<html>
 <head>
  <script type="text/javascript">
  function addMessage(counts){ //将服务器端发送回的信息更新到文本框
    var messageElement = document.getElementById("message");//获取id为message的文本框
    messageElement.innerHTML += counts; //将新信息添加到文本框
  }
  function f(){
    if(true){
     var iframeElement = document.getElementById("iframe");
     iframeElement.src = iframeElement.src;
     setTimeout(f, 30*1000);
    }
  }
  setTimeout(f, 30*1000); //定时器,实现每30秒调用一次函数f
  </script>
 </head>
 <body>
    <iframe id="iframe" src="test"></iframe>//通过src指向一个Servlet类,实现对服务器端的请求
    <style="display:none">
    <div id="message" style="height:400px; width:100%; overflow:scroll;"></div>
  </body>
</html>```
为实现客户端定时向服务器发送请求,通过在客户端添加一个定时器,定时时间为30×1000(以毫秒计算时间,即30秒)。当时间到达30秒后,通过调用函数f来更改iframe的src属性,重新向服务器发送请求,也就实现了轮询。

服务器返回给客户端的是一段js代码,该js代码调用了addMessage函数。该函数的作用是将新信息添加到id为message的div中。

####2.3.2 服务器端关键代码
服务器端的关键代码主要是在Servlet中,通过doGet方法来处理来自客户端的请求。

关键代码如下所示:

public class TestServlet extends HttpServlet{//子类TestServlet继承父类HttpServlet
  private int counts = 0; //私有成员变量counts
  @Override//覆盖父类的方法
  protected void doGet(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
    PrintWriter out = response.getWriter();//输出内容到客户端,就是用户的网页
    Out.println("");//调用show中的addMessage
    counts++;
   }
}`
接收到来自客户端的请求后,首先会通过response.getWriter()方法来获得一个响应的输出流,然后将counts计数信息连同包含它的js代码发送回客户端,客户端通过执行调用主页面的addMessage函数将counts信息进行显示。

2.3.3 案例系统运行效果

程序开始运行后,运行效果如图2-1所示。

51f90c80b82c8e5d3c2b79ed42c8921998f23598

当程序运行30秒后,数字增加1,运行效果如图2-2所示。

c607eae195896553dd1089f73dcf19d166fa99c1

程序每运行30秒,数字增加1,运行效果如图2-3所示。

0f7612575f8d6f55775b23866c8243013cc66f69
相关文章
|
7月前
|
XML 前端开发 JavaScript
PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑
本文深入探讨了PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑;Ajax则通过异步请求实现页面无刷新更新。文中详细介绍了两者的工作原理、数据传输格式选择、具体实现方法及实际应用案例,如实时数据更新、表单验证与提交、动态加载内容等。同时,针对跨域问题、数据安全与性能优化提出了建议。总结指出,PHP与Ajax的结合能显著提升Web应用的效率和用户体验。
159 3
|
7月前
|
前端开发 API 开发者
Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
在Web开发中,前后端的高效交互是提升用户体验的关键。本文通过一个基于Flask框架的博客系统实战案例,详细介绍了如何使用AJAX和Fetch API实现不刷新页面查看评论的功能。从后端路由设置到前端请求处理,全面展示了这两种技术的应用技巧,帮助Python Web开发者提升项目质量和开发效率。
146 1
|
8月前
|
机器学习/深度学习 移动开发 JavaScript
Web实时通信的学习之旅:SSE(Server-Sent Events)的技术详解及简单示例演示
Web实时通信的学习之旅:SSE(Server-Sent Events)的技术详解及简单示例演示
3222 0
|
8月前
|
前端开发 JavaScript API
惊呆了!学会AJAX与Fetch API,你的Python Web项目瞬间高大上!
在Web开发领域,AJAX与Fetch API是提升交互体验的关键技术。AJAX(Asynchronous JavaScript and XML)作为异步通信的先驱,通过XMLHttpRequest对象实现了局部页面更新,提升了应用流畅度。Fetch API则以更现代、简洁的方式处理HTTP请求,基于Promises提供了丰富的功能。当与Python Web框架(如Django、Flask)结合时,这两者能显著增强应用的响应速度和用户体验,使项目更加高效、高大上。
115 2
|
8月前
|
前端开发 API 开发者
从零到精通,AJAX与Fetch API让你的Python Web前后端交互无所不能!
从零到精通,AJAX与Fetch API让你的Python Web前后端交互无所不能!
95 3
|
8月前
|
网络协议 安全 JavaScript
Web实时通信的学习之旅:WebSocket入门指南及示例演示
Web实时通信的学习之旅:WebSocket入门指南及示例演示
817 0
|
8月前
|
前端开发 API 数据格式
颠覆传统!AJAX、Fetch API与Python后端,开启Web开发新篇章!
在Web开发领域,技术的快速迭代推动着应用不断进化。传统前后端交互方式已无法满足现代Web应用对高效、实时性和用户体验的需求。AJAX作为异步通信的先驱,使页面无需刷新即可更新部分内容,显著提升用户体验;尽管XML曾是其主要数据格式,但如今JSON已成为主流。Fetch API则以其简洁、灵活的特点成为AJAX的现代替代品,基于Promises的异步请求让开发更加高效。与此同时,Python后端凭借高效稳定和丰富的库支持,成为众多开发者的首选,无论是轻量级的Flask还是全功能的Django,都能为Web应用提供强大的支撑。
82 0
|
8月前
|
API C#
异步轮询 Web API 的实现与 C# 示例
异步轮询 Web API 的实现与 C# 示例
158 0
|
8月前
|
XML 前端开发 API
惊艳全场的秘诀!AJAX、Fetch API与Python后端,打造令人惊叹的Web应用!
惊艳全场的秘诀!AJAX、Fetch API与Python后端,打造令人惊叹的Web应用!
98 0

热门文章

最新文章