设为首页收藏本站

LUPA开源社区

 找回密码
 注册
文章 帖子 博客

Node.js开发指南:利用Socket.IO与doT提升性能表现

2013-10-28 13:46| 发布者: 红黑魂| 查看: 11092| 评论: 0

摘要: 教程介绍 难度: 中级 预计完成时间: 20分钟如果您的网站对于向客户机发送数据较为依赖,那么使用客户端模板以及WebSocket能够显著提高其性能表现。在今天的教程中,我们就一起来了解如何实现这一目标。简介我 们将以 ...


第四步: 客户端模板

为了着手提升应用性能,大家需要将 经过编译的模板保存在客户端当中。JavaScript文件会驻留在缓存当中,因此我们只要下载一次即可。为了编译模板,我们需要访问 http://olado.github.io/doT/index.html并下滚到Usage部分。由于我们不必在用户每一次访问网站时都对模板进行 编译,因此大家完全可以直接把编译后的函数添加到代码当中。打开post.dot文件,将其内容如下所示粘贴到Template字段当中:
 

现在将该字段的内容复制并粘贴到static/main.js文件的最初始位置。变更或者移除anonymous函数名称并将其分配至postTemplate变量,具体方式如下:

 

  1. varpostTemplate = function(it) { ... }

然后打开index.js文件并移除所有未使用的代码行,因为从现在开始,我们已经不必在服务器端对模板进行编译了:

 

  1. vardot = require('dot').template; 
  2. varfs = require('fs'); 
  3.   
  4. ... 
  5.   
  6. varpostTemplate = dot(fs.readFileSync('./post.dot')); 

post.dot 文件也可以删掉,没关系的。

第五步: 从AJAX到WebSocket

相 对于以往利用AJAX实现与服务器通信的做法,现在我们转而使用WebSocket。最好的办法是使用Socket.IO,这是因为WebSocket API本身并不提供故障转移功能——理由是用户的浏览器不支持。服务器已经设置完成,因此我们现在需要与之进行对接。首先,将下列代码添加到 static/index.html文件(在main.js之前)的head位置:

  1. <scriptsrcscriptsrc="/socket.io/socket.io.js"></script>

接下来,打开static/main.js文件并在模板definition之后添加以下代码:

  1. varsocket = io.connect(); 

它 将与Socket.IO服务器相连(请注意,大家必须提前将Socket.IO的脚本添加到页面当中)。由于在我们的实验环境中,服务器与客户端运行在同 一台主机当中,因此大家不必再为该函数添加任何额外参数。现在我们要做的是为该socket添加一个事件{敏感词},这样帖子内容获取完毕后我们就能及时得到 提示。将下列代码添加到之前代码行的后面:

  1. socket.on('getpost', function(data) { 
  2.    $('button').after(postTemplate(data)); 
  3. }); 

如大家所见,回调命令的内容与jQuery的$.ajax()方法中的success回调并无区别,但它会首先运行数据中的模板函数。现在,将$.ajax()调用替代为以下内容:

 

  1. socket.emit('getpost'); 

这一行代码的作用在于通知服务器,用户希望显示一篇新帖子。当然,在现实生活的应用程序内,服务器会在帖子发布后立刻加以发送。

第六步: 发送帖子

到这里,客户端已经能够与服务器对接并请求获取帖子内容,但服务器还无法正确响应随机帖子。现在我们打开index.js文件并对内容加以变更。由原本的:

  1. app.get('/getpost', function(req, res) { 
  2.    res.end(postTemplate(posts[Math.floor(Math.random() * 3)])); 
  3. }); 

变更为:

  1. io.sockets.on('connection', function(socket) { 
  2.    socket.on('getpost', function() { 
  3.       socket.emit('getpost', posts[Math.floor(Math.random() * 3)]); 
  4.    }); 
  5. }); 

这 将使服务器将getpost句柄与所有客户端相连,并利用随机帖子内容作为响应。现在大家可以再次运行应用程序以查看实际效果。接下来我们要再次打开浏览 器中的开发者工具、找到Network标签并加以过滤,这样大家就只会看到WebSocket。现在点击这个惟一可见的对象,大家应该看到浏览器与服务器 之间的传输的数据——是的,请求大小与文章开头的初始状态相比有了明显缩减。这是因为刚开始请求当中还包含有服务器端模板与AJAX内容(长度单位为‘字 节’):

总结

如各位所见,利用WebSocket以及客户端模板(几乎一定)能够改进应用程序的性能表现及耐用性。我敢肯定,很多网站都采用这种方式提升自己的响应效果。当然,我也希望各位朋友能够利用这项技巧为自己的移动及桌面系统用户带来更出色的使用体验。
 

原文链接:http://net.tutsplus.com/tutorials/javascript-ajax/node-js-better-performance-with-socket-io-and-dot/



酷毙

雷人

鲜花

鸡蛋

漂亮
  • 快毕业了,没工作经验,
    找份工作好难啊?
    赶紧去人才芯片公司磨练吧!!

最新评论

关于LUPA|人才芯片工程|人才招聘|LUPA认证|LUPA教育|LUPA开源社区 ( 浙B2-20090187 浙公网安备 33010602006705号   

返回顶部