欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

nodejs實(shí)現(xiàn)bigpipe異步加載頁面方案

 更新時(shí)間:2016年01月26日 09:21:16   投稿:hebedich  
本文給大家分享的是使用nodejs結(jié)合bigpipe實(shí)現(xiàn)異步加載頁面的方案,非常的實(shí)用,也是以后前端性能優(yōu)化的一個(gè)方向,希望大家能夠喜歡。

Bigpipe介紹

Facebook首創(chuàng)的一種減少HTTP請求的,首屏快速加載的的異步加載頁面方案。是前端性能優(yōu)化的一個(gè)方向。

BigPipe與AJAX的比較

AJAX主要是XMLHttpRequest,前端異步的向服務(wù)器請求,獲取動(dòng)態(tài)數(shù)據(jù)添加到網(wǎng)頁上。這樣的往返請求需要耗費(fèi)時(shí)間,而BigPipe技術(shù)并不需要發(fā)送XMLHttpRequest請求,這樣就節(jié)省時(shí)間損耗。減少請求帶來的另一個(gè)好處就是直接減少服務(wù)器負(fù)載。還有一個(gè)不同點(diǎn)就是AJAX請求前服務(wù)器在等待。請求后頁面在等待。BIGPIPE可以前后端并行工作也帶來了效率上的提升。

Bigpipe缺點(diǎn)

SEO問題。Facebook的動(dòng)態(tài)展現(xiàn)內(nèi)容主要是面向客戶的個(gè)性頁面。對于SEO的要求并不高。而如果把BIGPIPE技術(shù)用到淘寶上的話SEO的問題就會明顯了,現(xiàn)在不確定百度對于這種動(dòng)態(tài)頁面的搜索支持度如何,其實(shí)在使用ANGULARJS動(dòng)態(tài)綁定數(shù)據(jù)的時(shí)候也會有這方面的問題所以對于SEO有需求的頁面需要慎重考慮是否使用BIGPIPE技術(shù)。(已知GOOGLE搜索對于ANGULAR的SEO有優(yōu)化。)至于百度么-。-看下圖就知道了

NODEJS實(shí)現(xiàn)

bigpipe.js頁面引入的js

var Bigpipe=function(){
  this.callbacks={};
}

Bigpipe.prototype.ready=function(key,callback){
  if(!this.callbacks[key]){
    this.callbacks[key]=[];
  }
  this.callbacks[key].push(callback);
}

Bigpipe.prototype.set=function(key,data){
  var callbacks=this.callbacks[key]||[];
  for(var i=0;i<callbacks.length;i++){
    callbacks[i].call(this,data);
  }
}

app.js服務(wù)器代碼

var express = require('express');
var path = require('path');
var http = require('http');
var ejs = require('ejs');
var app = express();

app.set('port', process.env.PORT || 3000);
app.use(express.static(path.join(__dirname, 'public')));
app.engine('.html', ejs.__express);
app.set('view engine', 'html');
app.get('/index.html', function (req, res) {
  res.render('index', { title: "測試" }, function (err, str) {
    res.write(str)
  })
  var Pagelets_list ={
    pagelet1:false,
    pagelet2:false
  }
  var data = {is: "true"};
  function is_end(Pagelets) {
    Pagelets_list[Pagelets]=true;
    for (x in Pagelets_list) {
      if(!Pagelets_list[x]){
        return;
      }
    }
    res.end();
    return;
  }

  function Pagelets(Pagelets) {
    res.write('<script>bigpipe.set("' + Pagelets + '",' + JSON.stringify(data) + ');</script>');
    is_end(Pagelets)
  }
  setTimeout(function(){Pagelets("pagelet1");},1000);
  setTimeout(function(){Pagelets("pagelet2");},3000);
});

http.createServer(app).listen(3000);

index.html前端代碼

<!doctype html>
<html class="no-js">
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="description" content="">
  <meta name="keywords" content="">
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
  <title>zchq88-bigpipe</title>
  <!-- Set render engine for 360 browser -->
  <meta name="renderer" content="webkit">
  <!-- No Baidu Siteapp-->
  <meta http-equiv="Cache-Control" content="no-siteapp"/>
  <link  rel="stylesheet">
</head>
<body>
<div id="test1">loading......</div>
<div id="test2">loading......</div>
<script src="http://cdn.bootcss.com/jquery/2.1.4/jquery.min.js"></script>
<script src="http://cdn.bootcss.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
<script src="http://cdn.bootcss.com/angular.js/1.5.0-rc.0/angular.min.js"></script>
<script src="/js/bigpipe.js"></script>
<script>
  var bigpipe=new Bigpipe();
  bigpipe.ready('pagelet1',function(data){
    $("#test1").html("test1 ready");
  })
  bigpipe.ready('pagelet2',function(data){
    $("#test2").html("test2 ready");
  })
</script>
</body>
</html>

總結(jié)

Bigpipe技術(shù)其實(shí)具體實(shí)現(xiàn)需要服務(wù)器的代碼配合,在開發(fā)中我感覺功能占20%,優(yōu)化占80%的工作量,優(yōu)化的難度很多時(shí)候比開發(fā)還高。還需可能對全棧的了解。所以現(xiàn)在nodejs作為前后端分離的中間層是一個(gè)我個(gè)人認(rèn)為比較合理的一個(gè)解決方案。如果前后端完成nodejs的中間層分離,Bigpipe技術(shù)的實(shí)現(xiàn)將會是前端可以獨(dú)立完成的一個(gè)優(yōu)化。提高首屏加載時(shí)間。并且提高整個(gè)網(wǎng)頁的加載時(shí)間,對于瀏覽量的提升會帶來一定效果的。

相關(guān)文章

  • 使用travis-ci如何持續(xù)部署node.js應(yīng)用詳解

    使用travis-ci如何持續(xù)部署node.js應(yīng)用詳解

    最近在學(xué)習(xí)使用 travis-ci 對項(xiàng)目進(jìn)行持續(xù)集成測試,所以下面這篇文章主要給大家介紹了關(guān)于使用travis-ci如何持續(xù)部署node.js應(yīng)用的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-07-07
  • 我的Node.js學(xué)習(xí)之路(一)

    我的Node.js學(xué)習(xí)之路(一)

    這是一篇專門Node.js初學(xué)者學(xué)習(xí)筆記。該筆記將通過具體實(shí)例,教你一步步開始Node.js之旅。
    2014-07-07
  • autojs的Node.js正確退出腳本示例

    autojs的Node.js正確退出腳本示例

    這篇文章主要為大家介紹了autojs的Node.js正確退出腳本示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • 全面解析node 表單的圖片上傳

    全面解析node 表單的圖片上傳

    本文給大家介紹分享node全面解析表單的圖片上傳,本文給大家介紹的非常詳細(xì),具有參考借鑒價(jià)值,感興趣的朋友一起看看吧
    2016-11-11
  • node學(xué)習(xí)記錄之搭建web服務(wù)器教程

    node學(xué)習(xí)記錄之搭建web服務(wù)器教程

    本篇文章主要介紹了詳解node學(xué)習(xí)記錄——搭建web服務(wù)器,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-02-02
  • 如何用npm命令刪除開發(fā)項(xiàng)目中的node_modules文件夾

    如何用npm命令刪除開發(fā)項(xiàng)目中的node_modules文件夾

    每個(gè)項(xiàng)目都會產(chǎn)生一個(gè)node_modules,每個(gè)node_modules少則幾十兆,多則幾百甚至上千兆,隨著時(shí)間的積累,維護(hù)項(xiàng)目的增加,整個(gè)項(xiàng)目目錄體積會越來越大,這篇文章主要給大家介紹了關(guān)于如何用npm命令刪除開發(fā)項(xiàng)目中的node_modules文件夾,需要的朋友可以參考下
    2023-12-12
  • 淺談Node 調(diào)試工具入門教程

    淺談Node 調(diào)試工具入門教程

    這篇文章主要介紹了淺談Node 調(diào)試工具入門教程,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-03-03
  • Node如何后臺數(shù)據(jù)庫使用增刪改查功能

    Node如何后臺數(shù)據(jù)庫使用增刪改查功能

    這篇文章主要介紹了Node如何后臺數(shù)據(jù)庫使用增刪改查功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • NodeJS 文件夾拷貝以及刪除功能

    NodeJS 文件夾拷貝以及刪除功能

    這篇文章主要介紹了NodeJS 文件夾拷貝以及刪除功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09
  • Nodejs實(shí)現(xiàn)的操作MongoDB數(shù)據(jù)庫功能完整示例

    Nodejs實(shí)現(xiàn)的操作MongoDB數(shù)據(jù)庫功能完整示例

    這篇文章主要介紹了Nodejs實(shí)現(xiàn)的操作MongoDB數(shù)據(jù)庫功能,結(jié)合完整實(shí)例形式分析了nodejs針對MongoDB數(shù)據(jù)庫的連接及增刪改查基本操作技巧,需要的朋友可以參考下
    2019-02-02

最新評論