node上HTML分析利器node-jquery

简介:

      首先描述产生这篇随笔的场景:我需要获取项目在jenkins构建的最新Javascript Coverage显示在供管理层次查看的项目情况Report上,但是由于jenkins没有直接的API取得数据所需数据,所以我们只能从自建的容器发布Javascript Coverage数据API,供Report项目使用。

 

     由于采用简单的数据分析,只是Host一个简单web Server,所以本人不喜TomcatIIS这类大型工具,得有点杀鸡用牛刀,班弄斧。我更喜node.js这类简易web容器。所以目采用node.js,并node.js天然的javascripthtml操作的天然一体,借助DOM构使得解析Html更容易,简洁

      Node.js解析HTML DOM的当然是htmlpaserjsdom。然而个人更喜jQuery格,与web jQueryAPI,所以选择node-jquery.其代部署在Githubhttps://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 < arguments.length - 1; 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,欢迎指教。





 本文转自 破狼 51CTO博客,原文链接:http://blog.51cto.com/whitewolfblog/1141712,如需转载请自行联系原作者


相关文章
|
2月前
|
JavaScript
如何使用内存快照分析工具来分析Node.js应用的内存问题?
需要注意的是,不同的内存快照分析工具可能具有不同的功能和操作方式,在使用时需要根据具体工具的说明和特点进行灵活运用。
53 3
|
3月前
|
Java BI API
spring boot 整合 itextpdf 导出 PDF,写入大文本,写入HTML代码,分析当下导出PDF的几个工具
这篇文章介绍了如何在Spring Boot项目中整合iTextPDF库来导出PDF文件,包括写入大文本和HTML代码,并分析了几种常用的Java PDF导出工具。
726 0
spring boot 整合 itextpdf 导出 PDF,写入大文本,写入HTML代码,分析当下导出PDF的几个工具
|
3月前
|
XML JavaScript 数据格式
jquery中html()方法的使用
jquery中html()方法的使用
32 1
|
4月前
|
XML 前端开发 JavaScript
jQuery HTML / CSS 方法
jQuery HTML / CSS 方法
22 2
|
4月前
|
XML 前端开发 JavaScript
jQuery HTML / CSS 方法
jQuery HTML / CSS 方法
37 0
|
5月前
|
搜索推荐 Java API
Electron V8排查问题之分析 node-memwatch 提供的堆内存差异信息来定位内存泄漏对象如何解决
Electron V8排查问题之分析 node-memwatch 提供的堆内存差异信息来定位内存泄漏对象如何解决
139 0
|
5月前
|
JSON JavaScript 数据格式
html jquery from 表单提交 application/x-www-form-urlencoded 改成 json
html jquery from 表单提交 application/x-www-form-urlencoded 改成 json
54 0
|
6月前
|
前端开发 搜索推荐 UED
HTML表单提交的几种常用方式及其优缺点分析
HTML表单提交的几种常用方式及其优缺点分析
|
7月前
|
JavaScript 前端开发 安全
安全开发-JS应用&原生开发&JQuery库&Ajax技术&加密编码库&断点调试&逆向分析&元素属性操作
安全开发-JS应用&原生开发&JQuery库&Ajax技术&加密编码库&断点调试&逆向分析&元素属性操作
|
7月前
切方块游戏 HTML5+jQuery【附源码】
切方块游戏 HTML5+jQuery【附源码】
47 0