node上HTML分析利器node-jquery


まず、このエッセイを生成するシーンを説明します.jenkinsで構築されたプロジェクトの最新Javascript Coverageを管理階層で表示するためのプロジェクト状況Reportに表示する必要がありますが、jenkinsは直接APIでデータを取得するために必要なデータがないため、Javascript CoverageデータAPIを自社のコンテナから公開し、Reportプロジェクトで使用することができます.
 
简単なデータ分析を采用して、ただHost 1つの简単なweb Serverだけなので、本人はTomcat、IISのような大型のツールが好きではありませんて、少し鶏を杀して牛刀を使って、班门は斧を弄します.私はnodeのほうが好きです.jsのような簡単なwebコンテナ.だからプロジェクトはnodeを採用します.js,node.js天然javascriptはhtml操作と天然一体であり,DOM構造によりHtmlの解析が容易で簡潔である.
      Node.jsがHTML DOMを解析するのはもちろんhtmlpaser,jsdomです.しかし、個人的にはjQueryのスタイルが好きで、web jQueryとの統一APIが好きなので、node-jqueryを選んだ.そのコードはGithubのhttps://github.com/coolaj86/node-jquery. 
以下は私が簡単なdemoを書きます:Github Popular projectをつかんでコンソールで出力します.
   
   
   
   
  1. var $ = require('jquery'); 
  2.  
  3.   
  4.  
  5. String.format = function() { 
  6.  
  7.     var s = arguments[0]; 
  8.  
  9.     for (var i = 0; i 
  10.  
  11.         var reg = new RegExp("\\{" + i + "\\}""gm"); 
  12.  
  13.         s = s.replace(reg, arguments[i + 1]); 
  14.  
  15.     } 
  16.  
  17.   
  18.  
  19.     return s; 
  20.  
  21. }; 
  22.  
  23.   
  24.  
  25.  $.get("https://github.com/popular/forked",function(html){ 
  26.  
  27.   
  28.  
  29.         var $doc = $(html); 
  30.  
  31.     console.log("No.  name  language  star   forks  "
  32.  
  33.         $doc.find("ul.repolist li.source").each(function(i,project){ 
  34.  
  35.   
  36.  
  37.         var $project = $(project); 
  38.  
  39.                var name = $project.find("h3").text().trim(); 
  40.  
  41.                var language = $project.find("li:eq(0)").text().trim(); 
  42.  
  43.                var star = $project.find("li.stargazers").text().trim(); 
  44.  
  45.                var forks = $project.find("li.forks").text().trim(); 
  46.  
  47.                var row =String.format("{4} {0}  {1}  {2}  {3}",name, 
  48.  
  49.                        language,star,forks,i + 1 ); 
  50.  
  51.                
  52.  
  53.                console.log(row); 
  54.  
  55.         }); 
  56.  
  57.  }); 

 
このプロジェクトは私のGithubに泊まっています.https://github.com/greengerong/node-jquery-demo.node-jquery学習demoを理解するためにのみ、ご指導を歓迎します.