iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >如何提高AJAX客户端响应速度
  • 567
分享到

如何提高AJAX客户端响应速度

2024-04-02 19:04:59 567人浏览 薄情痞子
摘要

这篇文章主要介绍“如何提高ajax客户端响应速度”,在日常操作中,相信很多人在如何提高AJAX客户端响应速度问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何提高AJAX客户

这篇文章主要介绍“如何提高ajax客户端响应速度”,在日常操作中,相信很多人在如何提高AJAX客户端响应速度问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何提高AJAX客户端响应速度”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

笔者从事AJAX 方面的研发多年,参与开发了目前国内较为成熟的AJAX平台 -dorado 。根据笔者的经验,导致这种结果的根本原因并不在AJAX 。很多时候系统响应速度的降低都是由不够合理的界面设计和不够高效的编程习惯造成的。下面我们就来分析几个 AJAX 开发过程中需要时刻注意的环节。

<!-- [if !supportLists]-->n         <!-- [endif]-->合理的使用AJAX客户端编程和远程过程调用。

AJAX客户端的编程主要都是基于 javascript 的。而 JavaScript 是一种解释型的编程语言,它的运行效率相对于 Java 等都要稍逊一筹。同时 JavaScript 又是运行在浏览器这样一个严格受限的环境当中。因此开发人员对于哪些逻辑可以在客户端执行应该有一个清醒的认识。

在实际的应用中究竟应该怎样使用 客户端编程,这依赖于开发人员的经验判断。这里很多问题是只可意会的。由于篇幅有限,在这里我们大致归纳出下面这几个注意事项:

<!-- [if !supportLists]-->u       <!-- [endif]-->尽可能避免频繁的使用远程过程调用,例如避免在循环体中使用远程过程调用。

<!-- [if !supportLists]-->u       <!-- [endif]-->如果可能的话尽可能使用 AJAX 方式的远程过程调用(异步方式的远程过程调用)。

<!-- [if !supportLists]-->u       <!-- [endif]-->避免将重量级的数据操作放置在 客户端。例如:大批量的数据复制操作、需要通过大量的数据遍历完成的计算等。

<!-- [if !supportLists]-->n         <!-- [endif]-->改进对 DOM 对象的操作方式。

客户端的编程中,对 DOM 对象的操作往往是最容易占用 CPU 时间的。而对于 DOM 对象的操作,不同的编程方法之间的性能差异又往往是非常大的。

以下是三段运行结果完全相同的代码,它们的作用是在网页中创建一个 10x1000 的表格。然而它们的运行速度却有着天壤之别。

   var table = document.createElement("TABLE");   document.body.appendChild(table);   for(var i = 0; i < 1000; i++){     var row = table.insertRow(-1);     for(var j = 0; j < 10; j++){       var cell = objRow.insertCell(-1);         cell.innerText = "( " + i + " , " + j + " )";     }   }      var table = document.getElementById("TABLE");   document.body.appendChild(table);   var tbody = document.createElement("TBODY");   table.appendChild(tbody);   for(var i = 0; i < 1000; i++){     var row = document.createElement("TR");     tbody.appendChild(row);     for(var j = 0; j < 10; j++){       var cell = document.createElement("TD");         row.appendChild(cell);         cell.innerText = "( " + i + " , " + j + " )";     }   }      var tbody = document.createElement("TBODY");   for(var i = 0; i < 1000; i++){       var row = document.createElement("TR");          for(var j = 0; j < 10; j++){       var cell = document.createElement("TD");         cell.innerText = "( " + i + " , " + j + " )";         row.appendChild(cell);     }     tbody.appendChild(row);   }   var table = document.getElementById("TABLE");   table.appendChild(tbody);   document.body.appendChild(table);

这里的“测试代码 1 ”和“测试代码 2 ”之间的差别在于在创建表格单元时使用了不同的 api 方法。而“测试代码 2 ”和“测试代码 3 ” 之间的差别在于处理顺序的略微不同。

“测试代码 1 ”和“测试代码 2 ”之间如此大的性能差别我们无从分析,目前所知的是 insertRow 和 insertCell 是 Dhtml 中表格特有的 API , createElement 和 appendChild 是 W3C DOM 的原生 API 。而前者应该是对后者的封装。不过,我们并不能因此而得出结论认为 DOM 的原生 API 总是优于对象特有的 API 。建议大家在需要频繁调用某一 API 时,对其性能表现做一些基本的测试。

“测试代码 2 ”和“测试代码 3 ”之间的性能差异主要来自于他们的构建顺序不同。“测试代码 2 ”的做法是首先创建最外层的 <TABLE> 对象,然后再在循环中依次创建 <TR> 和 <TD> 。而“测试代码 3 ”的做法是首先在内存中由内到外的构建好整个表格,***再将它添加到网页中。这样做的目的是尽可能的减少浏览器重新计算页面布局的次数。每当我们将一个对象添加到网页中时,浏览器都会尝试对页面中的控件的布局进行重新计算。所以,如果我们能够首先在内存中将整个要构造的对象全部创建好,然后再一次性的添加到网页中。那么,浏览器将只会做一次布局的重计算 。总结为一句话那就是越晚执行 appendChild 越好。有时为了提高运行效率,我们甚至可以考虑先使用 removeChild 将已存在的控件从页面中移除,然后构造完成后再重新将其放置回页面当中。

<!-- [if !supportLists]-->n         <!-- [endif]-->提高字符串累加的速度

在使用 AJAX 提交信息时,我可能常常需要拼装一些比较大的字符串通过 XmlHttp 来完成 POST 提交。尽管提交这样大的信息的做法看起来并不优雅,但有时我们可能不得不面对这样的需求。那么 JavaScript 中对字符串的累加速度如何呢?我们先来做下面的这个实验。累加一个长度为 30000 的字符串。

    var str = "";   for (var i = 0; i < 50000; i++) {          str += "xxxxxx";   }

这段代码耗时 14.325 秒,结果并不理想。现在我们将代码改为如下的形式:

    var str = "";   for (var i = 0; i < 100; i++) {          var sub = "";          for (var j = 0; j < 500; j++) {                 sub += "xxxxxx";          }          str += sub;   }

这段代码耗时 0.359 秒!同样的结果,我们做的只是首先拼装一些较小的字符串然后再组装成更大的字符串。这种做法可以有效的在字符串拼装的后期减小内存复制的数据量。知道了这一原理之后我们还可以把上面的代码进一步拆散以后进行测试。下面的代码仅耗时 0.140 秒。

   var str = "";    for (var i1 = 0; i1 < 5; i1++) {          var str1 = "";          for (var i2 = 0; i2 < 10; i2++) {                 var str2 = "";                 for (var i3 = 0; i3 < 10; i3++) {                        var str3 = "";                        for (var i4 = 0; i4 < 10; i4++) {                               var str4 = "";                               for (var i5 = 0; i5 < 10; i5++) {                                      str4 += "xxxxxx";                               }                               str3 += str4;                        }                        str2 += str3;                 }                 str1 += str2;          }          str += str1;     }

不过,上面这种做法也许并不是***的!如果我们需要提交的信息是 XML 格式的(其实绝大多数情况下,我们都可以设法将要提交的信息组装成 XML 格式),我们还能找到更高效更优雅的方法 — 利用 DOM 对象为我们组装字符串。下面这段代买组装一个长度为 950015 的字符串仅须耗时 0.890 秒。

   var xmlDoc;     if (browserType == BROWSER_IE) {          xmlDoc = new ActiveXObject("Msxml.DOMDocument");   }   else {          xmlDoc = document.createElement("DOM");   }   var root = xmlDoc.createElement("root");   for (var i = 0; i < 50000; i++) {          var node = xmlDoc.createElement("data");          if (browserType == BROWSER_IE) {                 node.text = "xxxxxx";          }          else {                 node.innerText = "xxxxxx";          }          root.appendChild(node);   }   xmlDoc.appendChild(root);   var str;   if (browserType == BROWSER_IE) {          str = xmlDoc.xml;   }   else {          str = xmlDoc.innerHTML;   }   <!-- [if !supportLists]-->n

<!-- [endif]-->避免 DOM 对象的内存泄漏。

关于 IE 中 DOM 对象的内存泄露是一个常常被开发人员忽略的问题。然而它带来的后果却是非常严重的!它会导致 IE 的内存占用量持续上升,并且浏览器的整体运行速度明显下降。对于一些泄露比较严重的网页,甚至只要刷新几次,运行速度就会降低一倍。

比较常见的内存泄漏的模型有“ 循环引用 模型”、“ 闭包函数 模型”和“ DOM 插入顺序模型” , 对于前两种泄漏模型,我们都可以通过在网页析构时解除引用的方式来避免。而对于“ DOM 插入顺序模型”则需要通过改变一些惯有的编程习惯的方式来避免。

有关内存泄漏的模型的更多介绍可以通过 Google 很快的查到,本文不做过多的阐述。不过,这里我向您推荐一个可用于查找和分析网页内存泄露的小工具 — Drip ,目前的较新版本是 0.5 ,下载地址是 http://outofhanwell.com/ieleak/index.PHP

<!-- [if !supportLists]-->n         <!-- [endif]-->复杂页面的分段装载和初始化

对系统当中某些确实比较复杂而又不便使用 IFrame 的界面,我们可以对其实施分段装载。例如对于多页标签的界面,我们可以首先下载和初始化多页标签的默认页,然后利用 AJAH ( asynchronous JavaScript and HTML )技术来异步的装载其他标签页中的内容。这样就能保证界面可以在***时间首先展现给用户。把整个复杂界面的装载过程分散到用户的操作过程当中。

<!-- [if !supportLists]-->n         <!-- [endif]-->利用 GZIP 压缩网络流量。

除了上面提到的这些代码级的改良之外,我们还可以利用 GZIP 来有效的降低网络流量。目前常见的主流浏览器已经全部支持 GZIP 算法,我们往往只需要编写少量的代码就可以支持 GZIP 了。例如在 J2EE 中我们可以在 Filter 中通过下面的代码来判断客户端浏览器是否支持 GZIP 算法,然后根据需要利用 java.util.zip.GZIPOutputStream 来实现 GZIP 的输出。

   private static String getGZIPEncoding(httpservletRequest request) {     String acceptEncoding = request.getHeader("Accept-Encoding");     if (acceptEncoding == null) return null;     acceptEncodingacceptEncoding = acceptEncoding.toLowerCase();     if (acceptEncoding.indexOf("x-gzip") >= 0) return "x-gzip";     if (acceptEncoding.indexOf("gzip") >= 0) return "gzip";     return null;   }

一般而言, GZIP 对于 HTML 、 jsP 的压缩比可以达到 80% 左右,而它造成的服务端和客户端的性能损耗几乎是可以忽略的。结合其他因素,支持 GZIP 的网站有可能为我们节约 50% 的网络流量。因此 GZIP 的使用可以为那些网络环境不是特别好的应用带来显著的性能提升。使用 Http 的监视工具 Fiddler 可以方便的检测出网页在使用 GZIP 前后的通讯数据量。 Fiddler 的下载地址是 http://www.fiddlertool.com/fiddler/

关于 WEB 应用的性能优化其实是一个非常大的话题。本文由于篇幅有限,只能涉及其中的几个细节,并且也无法将这些细节的优化方式全面的展现给大家。期望本文能够引起大家对 Web 应用尤其是客户端性能优化的充分重视。毕竟服务端编程技巧已为大家熟知多年,在服务端挖掘性能的潜力已经不大了。而在客户端的方法改进往往能够得到令人惊奇的性能提升。

到此,关于“如何提高AJAX客户端响应速度”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: 如何提高AJAX客户端响应速度

本文链接: https://www.lsjlt.com/news/73155.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何提高AJAX客户端响应速度
    这篇文章主要介绍“如何提高AJAX客户端响应速度”,在日常操作中,相信很多人在如何提高AJAX客户端响应速度问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何提高AJAX客户...
    99+
    2024-04-02
  • AJAX如何提高客户端响应速度
    这篇文章将为大家详细讲解有关AJAX如何提高客户端响应速度,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 理论上AJAX技术在很大的程度上可...
    99+
    2024-04-02
  • 如何提高MySQL响应速度
    如何提高MySQL响应速度,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、概述二、应用场景MySQL自身的局限性,很多站点都...
    99+
    2024-04-02
  • php项目的响应速度如何提高
    这期内容当中小编将会给大家带来有关php项目的响应速度如何提高,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。PHP开发环境搭建工具有哪些一、phpStudy,是一个新手入门最常用的开发环境。二、WampS...
    99+
    2023-06-14
  • ASP API响应开发技术:如何提高响应速度?
    ASP API是一种常见的后端开发技术,用于构建Web API或RESTful API。在API开发中,响应速度是一个非常重要的指标,因为快速响应可以提高用户体验和API的可用性。本文将介绍一些ASP API响应开发技术,帮助你提高API...
    99+
    2023-06-26
    api 响应 开发技术
  • 如何提高香港服务器响应速度
    提高香港服务器响应速度的方法:1、减少http请求次数;2、尽量使用静态页面;3、优化香港服务器网站代码;4、利用香港服务器里面的Gzip页面压缩功能;5、对香港服务器的网站使用iframe嵌入网络广告;6、提高香港服务器的配置。具体内容如...
    99+
    2024-04-02
  • 实时日志如何提高ASP响应速度?
    ASP(Active Server Pages)是一种动态网页开发技术,它使用VBScript或JScript来编写脚本,通过IIS(Internet Information Services)来处理HTTP请求,并生成动态网页。在ASP...
    99+
    2023-07-21
    响应 实时 日志
  • 如何利用PHP索引提高响应速度?
    PHP是一种非常流行的Web编程语言,它被广泛应用于各种Web应用程序的开发中。在开发Web应用程序时,一个非常重要的问题就是如何提高响应速度,使得用户可以更快地获取到需要的信息。在这篇文章中,我们将介绍如何利用PHP索引来提高响应速度。 ...
    99+
    2023-07-01
    响应 索引 并发
  • ASP.NET MVC 如何使用索引提高响应速度?
    在处理大量数据时,ASP.NET MVC 应用程序可能会变得非常缓慢,这可能会降低用户体验并导致用户流失。为了解决这个问题,可以使用索引来提高 ASP.NET MVC 应用程序的响应速度。在本文中,我们将探讨什么是索引以及如何在 ASP....
    99+
    2023-08-12
    索引 响应 spring
  • 如何提高网站服务器的响应速度
    提高网站服务器响应速度的方法:1、使用服务器搭建网站程序时,需要减少http请求数,从而提高网站响应速度;2、给网站服务器接入CDN加速工具,从而改善网络环境,给予用户良好的体验感;3、选择域名解析速度快的DNS服务器,从而降低DNS查询时...
    99+
    2024-04-02
  • Go、Git和Unix:如何提高Web应用的响应速度?
    随着互联网的发展,Web应用的响应速度越来越受到关注。用户的耐心越来越短,对于网站或应用程序的响应速度要求越来越高。在这种情况下,如何提高Web应用的响应速度成为了一个重要的问题。本文将介绍如何利用Go、Git和Unix来提高Web应用的...
    99+
    2023-07-28
    git 响应 unix
  • PHP API Load 开发技术:如何提高响应速度?
    随着互联网应用的不断发展,API(Application Programming Interface)的重要性也越来越受到人们的重视。而在使用API时,响应速度是一个非常重要的指标。本文将介绍一些PHP API Load开发技术,以帮助您...
    99+
    2023-06-08
    api load 开发技术
  • 如何在 PHP 中使用 NumPy 以提高响应速度?
    PHP 是一种广泛使用的编程语言,主要用于 Web 开发。然而,PHP 的响应速度并不总是能够满足开发者的需求。为了提高响应速度,开发者可以使用 NumPy 库。NumPy 是一个用于处理大型多维数组和矩阵的 Python 库,它提供了高效...
    99+
    2023-08-30
    numy numpy 响应
  • PHP 响应文件同步问题:如何确保迅速响应客户端请求?
    当客户端发送请求到服务器时,服务器需要迅速响应客户端的请求。在 PHP 中,处理文件同步的过程可能会对响应时间产生影响。在本文中,我们将探讨如何确保 PHP 在处理文件同步时能够快速响应客户端请求。 使用异步处理 使用异步处理可以让 ...
    99+
    2023-09-02
    响应 同步 文件
  • 如何优化 Java 路径以提高 Load 响应速度?
    Java 是一种广泛使用的编程语言,许多企业都在使用 Java 应用程序来提供服务。在 Java 应用程序中,路径是非常重要的。路径是指用于查找文件、资源、目录和类的字符串。在 Java 应用程序中,路径的优化可以提高应用程序的 Load ...
    99+
    2023-07-27
    path 响应 load
  • 大数据存储中,Java如何提高响应速度?
    随着大数据应用场景的不断扩大,大数据存储成为了一个重要的领域。而Java作为一种主流的编程语言,也逐渐成为大数据存储的首选语言之一。在大数据存储中,Java如何提高响应速度呢?本文将会从以下几个方面进行探讨。 一、优化IO操作 Java中的...
    99+
    2023-08-13
    大数据 存储 响应
  • ASP和Linux:如何使用数组来提高响应速度?
    对于网站开发者来说,提高网站的响应速度是至关重要的。ASP和Linux是两个常用的开发平台,它们都有自己的优点和缺点。但是,无论你使用哪种平台,使用数组来提高响应速度都是一个非常有效的方法。 在ASP中,数组可以用来存储大量的数据,并且可...
    99+
    2023-10-27
    linux 响应 数组
  • 如何在 PHP 中使用数组来提高响应速度?
    PHP 是一种强大的编程语言,广泛用于 Web 应用程序的开发。当处理大量数据或需要快速响应用户请求时,PHP 数组成为一种重要的工具。在本文中,我们将探讨如何使用 PHP 数组来提高响应速度。 PHP 数组是一种非常灵活的数据结构,可以存...
    99+
    2023-08-31
    数组 学习笔记 响应
  • PHP 防抖技术:提高用户操作的流畅度和响应速度
    在开发网页应用程序时,用户操作的流畅度和响应速度是至关重要的。一个常见的问题是,用户在连续点击或频繁触发某个功能按钮时,会导致服务器端接收到大量的请求,从而影响网页的性能和用户体验。为了解决这个问题,我们可以使用PHP防抖技术来限制用户的操...
    99+
    2023-10-21
    PHP 流畅度 防抖
  • ASP中如何实现异步编程以提高响应速度?
    在互联网时代,用户对网站的响应速度要求越来越高,而网站的响应速度与服务器端的性能息息相关。ASP是一种非常流行的服务器端开发语言,它的高性能和易用性使得它成为了众多网站的首选。但是,ASP在处理大量并发请求时会遇到性能瓶颈,这时候就需要使...
    99+
    2023-10-27
    异步编程 响应 leetcode
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作