Project

html-tag

0.0
Low commit activity in last 3 years
No release in over a year
Fast and powerful tag builder, upgrade to Rails tag helper, framework agnostic.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies
 Project Readme

HTML Tag builder

HTML tag builder "on steroids"

https://github.com/dux/html-tag

Install

Gemfile

gem 'html-tag'

Manual require

require 'html-tag'

Usage

Example

import HtmlTag

tag.ul do
  # html tags are accessible as mmethods
  li do
    a href: '#', class: method_in_caller_scope
  end

  # instance variables are accesible
  @list.each_with_index do |el, i|
    li el, num: i
  end

  # custom tags
  tag 'svelte-clock', city: 'London'

  # order of data is not immportant
  a({href: '#'}, name)
  a(name, {href: '#'})

  # class name shrocuts
  _foo__bar_baz # <div class="foo bar-baz"></div>

  # push any data
  push ' &sdot; '
end

Advanced

Useable without importing HtmlTag.

# if you pass node name as a argument, block will be executed in HtmlTag instance scope
HtmlTag :ul do
  li do
    a link_to, href: '#'
  end
end

# if you want code to be executed in host scope, use pointer and this syntax (preferred)
HtmlTag.ul do |n|
  n.li do
    n.a link_to, href: '#'
  end
end

You do not have to import HtmlTag, you can inject tag method in Class or Module without polluting ancestors namespace.

class Foo
  # instead
  include HtmlTag

  # or
  prepend HtmlTag

  # you can use
  HtmlTag self
end

More examples

Tag without data

= HtmlTag.div
<div></div>

Empty tags

= hr
= meta name: :foo, description: :bar
<hr />
<meta name="foo" description="bar" />

Tag with block data

If block does not have child nodes and returns string, string will be used as data.

= div { 'foo' }
<div>foo</div>

Tag with inline data and no params

= div('baz')
<div>baz</div>

Tag with inline data and params

= div('baz', {foo: :bar})
<div foo="bar">baz</div>

Tag with class shortcut

= _foo
= _foo__bar_baz 123, class: 'dux'
<div class="foo"></div>
<i class="foo bar-baz dux">123</i>

Tag with nested opts and shortcut

= _miki(id: :foo, data: { bar: :baz })
<div id="foo" data-bar="baz" class="miki"></div>

Tag with nested data and manual push

HtmlTag class: :foo do
  ul do
    li do
      a 'baz 1', href: '#'
      a 'baz 2', href: '#'
    end

    push 123

    node :foo, :bar
  end
end
<div class="foo">
  <ul>
    <li>
      <a href="#">baz 1</a>
      <a href="#">baz 2</a>
    </li>
    123
    <foo>bar</foo>
  </ul>
</div>

Renders tag from String base

'foo'.tag(:bold, class: :baz)
<bold class="baz">foo</bold>

Renders tag from Hash base

{ class: :baz }.tag(:bold, 'foo')
<bold class="baz">foo</bold>

Speed test

Compares Nokogiri::XML::Builder with two modes for html-tag.

rake speed

Dependency

none

Development

After checking out the repo, run bundle install to install dependencies. Then, run rspec to run the tests.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/dux/html-tag. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.

License

The gem is available as open source under the terms of the MIT License.