24、使用 Hpricot 解析 HTML、XHTML、XML 与 RSS 提要

Hpricot解析HTML与RSS实战

使用 Hpricot 解析 HTML、XHTML、XML 与 RSS 提要

1. 后处理 HTML 输出

1.1 问题描述

在使用 Ruby Web 框架(如 Ruby on Rails、Merb 或 Nitro)时,有许多页面会生成表格,希望所有表格在浏览器渲染时具有斑马线效果(偶数行显示浅蓝色)。但尝试过使用客户端 JavaScript 代码,由于部分表格较大,页面加载时间过长;手动确保表格条纹效果又因创建表格的机制过多而变得繁琐。不过,为需要条纹效果的表格添加特定类(如 zebra)并不困难。

1.2 解决方案

使用 Hpricot 对渲染后的页面进行后处理,为每隔一行设置适当的样式,再通过 CSS 样式表引入该样式。以下是 Ruby on Rails 的示例代码:

class ApplicationController < ActionController::Base
  after_filter :zebra
  def zebra
    doc = Hpricot(response.body)
    doc.search("table.zebra tbody tr:nth-child(even)").add_class("even")
    response.body = doc.to_s
  end
end

CSS 样式如下:

.zebra .even {
  background-color: #ddf;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值