html - 查找分配给元素的 CSS 样式

标签 html css ruby nokogiri

获取元素的渲染样式 (也应该能够处理内联 CSS)

我一直在学习Nokogiri并了解如何根据 ID 或类选择节点。但是,我想选择一个节点/元素并获取分配给它的特定 CSS 样式,包括继承的样式。

CSS 样式表:

<head>
  <style type="text/css">
    .myfont {font-family: Times New Roman: font-size: 80% }
    .bold {font-weight: bold}
    .50_font_size { font-size:50% }
   </style>
 </head>

HTML:

<Body>
   <div id="article1" class="myfont">
      <div id="title1" class="bold">  
          My Title Text
          <div id="author1" class="50_font_size">
             By First Name Last Name
          </div>
      </div>
        General article text. General article text. General article text.        
      </div>
   </div>

在上面的例子中,我想使用...

require "nokogiri"
document=Nokogiri.HTML(HTML_String)

#Hoping for something like the following:
author_css = node.css_style("author1") 
puts author_css
#=>  {font-family=>"Times New Roman",
#=>   font-weight=> "bold",
#=>   font-size=> 50%} 

正如你所看到的,它应该输出继承的元素,以便我获得元素的正确 CSS。获得此结果的最佳方法是什么?

最佳答案

仅靠 Nokogiri 是无法做到这一点的。使用CSS_Parser将提供缺少的部分:

require 'nokogiri'
require 'css_parser'
include CssParser

html = <<END_HTML
<head>
  <style type="text/css">
    .myfont {font-family: Times New Roman: font-size: 80% }
    .bold {font-weight: bold}
    .50_font_size { font-size:50% }
  </style>
</head>
<body>
  <div id="article1" class="myfont">
      <div id="title1" class="bold">  
          My Title Text
          <div id="author1" class="50_font_size">
            By First Name Last Name
          </div>
      </div>
        General article text. General article text. General article text.        
      </div>
  </div>
</body>
END_HTML

doc = Nokogiri::HTML(html)
css = doc.at('style').text

parser = CssParser::Parser.new
parser.add_block!(css)

author_div = doc.at('div#author1')
puts parser.find_by_selector('.' + author_div['class'])

哪些输出:

font-size: 50%;

要获取继承的 CSS,您需要从文档顶部开始,向下钻取到所需的节点,找出哪些父节点的设置将影响您的目标节点。

关于html - 查找分配给元素的 CSS 样式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14573703/

相关文章:

mysql - 我应该知道数据库表行的 "directly proportional growing"和日志文件中 SQL 查询的长度吗?

javascript - 从用户在 HTML 和 Javascript 中输入的数字开始倒计时

javascript - 延迟一个接一个地动画 sibling

javascript - 隐藏的幻灯片不会在隐藏容器内扩展全宽

css - Ionic v4 ion-img 急切加载图像而不是延迟加载

ruby-on-rails - 在 Rails 中实现查找表

ruby-on-rails - Rails 缓存计数器

javascript - 如何让 metisMenu 在鼠标悬停时自动展开?

html - IE10 - RTL 反转 - 如何修复?

html - 右边的下拉菜单