Project

role-haml

0.01
No commit activity in last 3 years
No release in over 3 years
Gem for jQuery plugin to provide easy way to handle DOM elements by role attribute
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

>= 1.0.0
>= 3.0.0

Runtime

>= 3.1.0
 Project Readme

This is gem for Haml support for jQuery plugin role by @kossnocorp

Sponsored by Evil Martians.

Usage

app/views/home/index.html

%a@some-role@another-role( href='#' )
  Hello

@div-role
  Div Hello

Will produce:

<a role='some-role another-role' href='#'>Hello</a>

<div role='div-role'>Div Hello</div>

Install

In your Gemfile:

gem 'role-haml'

Contributors

Original version of gem for rails you can find here - role-rails It was written by @kossnocorp, @yury, @rwz, @chrome, @igor-alexadrov, @alno

License

MIT (look into repo LICENSE)

jQuery plugin role readme

This project uses Semantic Versioning for release numbering.

Downloads

Also you can add jquery.role.js and role.js by bundle role-rails gem. For futher details see installation section below.

Use role attribute FTW

Use cases for a role attribute for HTML5, include:

* accessibility,
* device adaptation,
* server-side processing, and
* complex data description.

This is a quote from W3C Specification on Role attribute.

In Evil Martians we came up with a way to use this attribute for our own purposes.

Say you have to update your website page design. HTML markup is done and you have to apply it to the existing site. Of course this marvelous page is crammed with Javascript code tied to an existing structure.

$('.list .item img')
    .mouseenter(function () {
        $(this).rotateTo(30, 300)
    })
    .mouseleave(function () {
        $(this).rotateTo(0, 300)
    });

Obviously, you'll have to rewrite all the selectors for the new layout. And it would be nice if you had to fix only one (or even ten) of these selectors. In reality, most likely, there will be several dozen of them.

Another issue is that refactoring process requires you to change the names or a number of classes. You'll have to muddle through every JS file to find all classes you are going to change.

And, of course, in both cases the end result is absolutely unpredictable, because layout alone is not enougn to figure out if a class is actualy used in JS.

The .js-class_name prefix use may seem like a good idea, except that someone will surely add styles to this class in a future... Let alone the difficulty to spot, among a large of number of classes, one with a prefix.

In order to avoid this problems, we can "attach" JS to DOM elements by a role attribute.

It's a lot safer then prefixes, beacause it's much harder to attach styles to role and it feals morally difficult to break the role use convention.

With the use of role, layout update becomes very straightforward: you just have to add roles to a new element, and if you are not tied to the "magic numbers" -- it will work with no further hassle.

To make life easier (shoutout to @alex_chrome for the great idea) we also extended jQuery selector syntax:

$('@list @item @image')
    .mouseenter(function () {
        $(this).rotateTo(30, 300)
    })
    .mouseleave(function () {
        $(this).rotateTo(0, 300)
    });

$('@list @item @image') is the same as $('[role="list"] [role="item] [role="image"]') and you can use "multirole": $('@list@coupons').

In addition to the jQuery plug-in, I also wrote a version that extends querySelectorAll of Zepto.js with a Role functionality.

Using of 'role' in a query may work a bit slower compared to usual selectors, but it's neglectable even in a large number of queries.

In addition to role, I sometimes use id, but only in very extraodinary cases — because if there is only single element on a page today, it may happen that there will be a few tomorrow, even if that wasn't planned.

Usage

Using selectors

You can use shortcut @ in jQuery selectors to find elements with roles.

Will select all elements in document with role="ajax-link":

$('@ajax-link')

Also you can combinate roles:

<form role="form login_form"></form>:

$('@form@login_form')

Will select all forms with "form" as role <form role="form login_form"></form><form role="form registration_form"></form>:

$('@form')

You can combine role with other selectors, but that is not recommended:

<form class="dark" role="login_form" method="post"></form>:

$('form.dark@login_form[method=post]')