"爱说说"技术原理:前端Javascript优化技巧(四)

上一节:爱说说技术原理:前后台参数约定及逻辑代码 中,讲解了“爱说说”的后台简单的逻辑处理代码。

 

本节,看一下前端的逻辑及优化事项[爱说说http://speak.cyqdata.com/ ]

 

前言说明:





1:前端没有使用JQ,采用原生的XmlHttp做为异步请求。



2:前端代码就不多贴了,直接查看页面源文件就能看到所有的代码了。







 

以下讲一下“爱说说”在这个过程中优化过的注意事项:

[PS:事隔这么久,好多都忘了,只能靠点回忆代码来写了]

 

一:基础优化

 

1:避免直接用控件循环加载html,而用变量组合html,最后一次给控件的innerHTML赋值:





不良用法:for(i in json.data){$('div').innerHTML+=json.data[i].Name;}



正规用法:var html;for(i in json.data){html+=json.data[i].Name;}$('div').innerHTML=html;







 

2:定义的对象或变量,用完后,赋null值:



var a;.....使用a.....a=null;//用完赋null值。



 

二:逻辑优化

 

1:客户端基本请求策略:








1:首次请求,加载1页数据40条消息,后面可以点击显示更多,每次40条消息。



消息显示难点:40条中可能包含回复,而回复的主留言可能在40之外,因此,对于回复,如果找不到父ID,即主留言,临时存储到数组中,等用户点击更多时,再看看有没有父ID存在,有就挂下去补充,没有继续存储等待更多...如果重复的说。



2:定时请求,请求从消息的尾步开始,每次请求后拿取maxID,下次根据maxID请求后续内容。










 

2:客户端基本优化策略

 

1:代码重用,函数封装,优化调用

 

2:定时器的策略,优化请求资源







 function getNewMsgCallBack(result,callByTimer)
 {
    loadCallBack(result,callByTimer);
    if(callByTimer)//系统定时器
    {
        IdleTimes++;//设置空闲次数
        switch(IdleTimes)
        {
            case 8://1分钟没发言,将会16秒刷新一次
            case 16://3分钟没发言[又过了16*8秒],将会32秒刷新一次
            case 24://7分钟没发言[又过了32*8秒],将会64秒刷新一次
                handleTime=handleTime*2;//定时器时间加倍
                clearTmer();//取消刷新
                timer();//开始新的计时刷新
                break;
            case 75://1小时没反应,自动刷新。
                location.href=location.href;
            break;
        }
    }
    else
    {
        IdleTimes=0;//用户发表信息,恢复定时器
        if(handleTime!=8000)
        {
             handleTime=8000;//定时器时间还原
             clearTmer();//取消刷新
             timer();//开始新的计时刷新
        }
    }
 }









PS:从这段代码看,策略是对于不聊天的人群,采用步步拉大请求时间,节省服务器请求资源。

 

3:聊天策略,优化加载,聊天流畅








原因:如果在打字的时候,刚好遇到消息回来并加载显示的过程,界面会变的相当的卡。



因此策略是:聊天时,停止消息加载,发布消息后,恢复消息加载。



具体:



光标定位到打字框时,设置标识



停止加载-》存储未加载的对象到数组中[到下次请求时一起显示]-》发表留言[恢复标识]










 

4:小技巧避开“点击”,引发音乐切换





原因:<a href="javascript:xxx()"...的方式的点击会引起iframe 的音乐链接重新加载,从而音乐自动切换了。



解决:<a href="###" onclick="xxx()"...换成这种方式即可以了。







 

5:适当避开快速聊天,限制“发布”按钮





发布消息时,将“发布”按钮置不可用,等下次消息回来时,再恢复“发布”按钮的可用状态,因此两次聊天的时间间隔是“1-8”秒之间。





 



本节就介绍到了,其它的不容易想,感兴趣的自行研究了。



 



相关文章:




1:爱说说技术原理方案的定选思考过程



2:爱说说技术原理:与TXT交互及MDataTable对Json的功能扩展



3:爱说说技术原理:前后台参数约定及逻辑代码



版权声明:本文原创发表于博客园,作者为路过秋天,原文链接:



http://www.cnblogs.com/cyq1162/archive/2011/06/24/2088902.html





时间: 2024-11-08 18:28:27

"爱说说"技术原理:前端Javascript优化技巧(四)的相关文章

&quot;爱说说&quot;技术原理:与TXT交互及MDataTable对Json的功能扩展(二)

关于爱说说在技术选型的文章见:"爱说说"技术原理方案的定选思考过程   本篇将讲述"爱说说"比较重大的技术问题点及解决手段:   爱说说:http://speak.cyqdata.com/   杂说几句: 一开始,原本是打算在秋式开源团队找一JS人才来引导前台页面的呈现的,毕竟本人在JS还停留在原始的编码阶段,于是当时聊了一下. 再后来,接下来几天,由于秋式开源团队内部管理上有点小调整,还有新开任务小组的事,连续忙了几天,"爱说说"就也停了几天.

&quot;爱说说&quot;技术原理:前后台参数约定及逻辑代码(三)

上一节:"爱说说"技术原理:与TXT交互及MDataTable对Json的功能扩展 中,   我们解决了TXT数据存储和Json的交互问题,本节,看一下后台的业务逻辑:   爱说说:http://speak.cyqdata.com/ [当前版本已增加了音乐和表情]   先看Page_Load事件:       public override void Page_Load()         {             if (day == 0)//首次初始化             {

Javascript优化技巧之短路表达式详细介绍

 这篇文章主要介绍了Javascript优化技巧之短路表达式详细介绍,本文讲解了什么是短路表达式,并给出了一些示例,需要的朋友可以参考下     什么是短路表达式? 短路表达式:作为"&&"和"||"操作符的操作数表达式,这些表达式在进行求值时,只要最终的结果已经可以确定是真或假,求值过程便告终止,这称之为短路求值.这是这两个操作符的一个重要属性. 一个最简单的例子:   代码如下: foo = foo||bar;   这行代码是什么意思?答案:  

JavaScript事件委托的技术原理探讨示例_javascript技巧

如今的JavaScript技术界里最火热的一项技术应该是'事件委托(event delegation)'了.使用事件委托技术能让你避免对特定的每个节点添加事件监听器:相反,事件监听器是被添加到它们的父元素上.事件监听器会分析从子元素冒泡上来的事件,找到是哪个子元素的事件.基本概念非常简单,但仍有很多人不理解事件委托的工作原理.这里我将要解释事件委托是如何工作的,并提供几个纯JavaScript的基本事件委托的例子. 假定我们有一个UL元素,它有几个子元素: 复制代码 代码如下: <ul id=&qu

Javascript优化技巧(文件瘦身篇)_javascript技巧

最近一直在研究 Javascript 相关的技术.在<Javascript 高级程序设计>有篇章节着重阐述了优化 Javascript 代码的重要性.相信有很多的 Javascript 开发人员在开发的同时或多或少的会接触到此类的问题. 在大部分情况下,代码的优化并不是实际开发中所需要着重的部分.但是一旦代码完成了以后,开发者总是期待自己的代码能够越短越高效越好.结合从书中获得的知识以及本人实际开发过程中的经验,下面说明本人所采取的一些花招(也算是照本宣科一下). 前言 相比脚本语言,编译型的

Javascript优化技巧之短路表达式详细介绍_javascript技巧

什么是短路表达式? 短路表达式:作为"&&"和"||"操作符的操作数表达式,这些表达式在进行求值时,只要最终的结果已经可以确定是真或假,求值过程便告终止,这称之为短路求值.这是这两个操作符的一个重要属性. 一个最简单的例子: 复制代码 代码如下: foo = foo||bar; 这行代码是什么意思?答案: 复制代码 代码如下: //如果foo存在,值不变,否则把bar的值赋给foo if(!foo)     foo = bar; 在javascrip

前端性能优化(三)——传统 JavaScript 优化的误区

注:本文是纯技术探讨文,无图无笑点,希望您喜欢 一.前言 软件行业极其缺乏前端人才这是圈内的共识了,某种程度上讲,同等水平前端的工资都要比后端高上不少,而圈内的另一项共识则是--网页是公司的脸面! 几年前,谷歌的一项统计表明,如果亚马逊页面加载每慢 100ms,将影响他们 1% 的收入:如果谷歌页面加载慢 500ms,流量将锐减 20%,这个数据现在必将更加恐怖! 在前端高性能优化(一).(二)中,笔者介绍了一些关于前端优化的技术,这些技术都依赖于前人的辛苦努力,但我们仍要明白的是,前端的情况十

前端性能优化及技巧_javascript技巧

    前言        为什么要优化性能对于前端工程师如此重要           在行业内有句话不知道大家有没有听说过,'懂得性能优化并且研究过jquery源代码的人和不懂得性能优化写出来的代码对于性能的消耗会相差上百倍甚至上千倍',现在的javascript属于从ECMAscript3到ECMAscript5以及ECMAscript6的一个过渡的过程.在javascript的编写不健全的时候编写代码方法不得当,引起的问题也是不容忽视的.     性能优化     下面将自己对于性能优化的

JavaScript 性能优化技巧分享

JavaScript 作为当前最为常见的直译式脚本语言,已经广泛应用于 Web 应用开发中.为了提高Web应用的性能,从 JavaScript 的性能优化方向入手,会是一个很好的选择. 本文从加载.上下文.解析.编译.执行和捆绑等多个方面来讲解 JavaScript 的性能优化技巧,以便让更多的前端开发人员掌握这方面知识.   什么是高性能的 JavaScript 代码? 尽管目前没有高性能代码的绝对定义,但却存在一个以用户为中心的性能模型,可以用作参考:RAIL模型. 响应 如果你的应用程序能