SimpleSelector

SimpleSelector is a Ruby gem that represents a CSS-like selector, calculates its specificity and tells if it matches given HTML-like tags.

Content

The selector content can consist of tag names, IDs and class names. An example:

  SimpleSelector.new("tag_a#id_a.class_a #id_b .class_c.class_d")

Specificity

Calculation rules

The specificity of a selector is calculated according to rules similar to the standard CSS rules.

The specificity is four numbers: a,b,c,d.

The rules respected by this gem are:

  • a is always 0;
  • b is the number of ID attributes in the selector;
  • c is the number of class names in the selector;
  • d is the number of tag names in the selector.

For example, a selector tag#id1.class1 #id2.class2.class3 has specificity equal to 0,2,3,1.

  SimpleSelector.new("tag#id1.class1 #id2.class2.class3").specificity
   => #<SimpleSelector::Specificity "0,2,3,1">

Comparison

Specificity allows selector comparison.

Two selector specificities are compared by succesively comparing their corresponding numbers, from left to right.

Tag matching

A SimpleSelector object tells if it matches given HTML-like tags.

The tag is expected to be represented by an object which responds to :name, :id, :class_names and :parent messages. An example:

  Tag = Struct.new(:name, :id, :class_names, :parent)

  # Tag objects corresponding to the structure:
  # <section id="content"><message class="success">...</message></section>
   = Tag.new("section", "content", [], nil)
  message_tag = Tag.new("message", nil, ["success"], )

And now:

  SimpleSelector.new("section#content message.success").match?(message_tag)
   => true

Installation

As a Ruby gem, SimpleSelector can be installed either by running

  gem install simple_selector

or adding

  gem "simple_selector"

to the Gemfile and then invoking bundle install.

License

License is included in the LICENSE file.