Pull to refresh

RegEx Selector для jQuery

Reading time1 min
Views28K
Original author: James Padolsey
Всем давно известно, что jQuery легко расширяем. Сегодня мы добавим новый селектор — :regex.



Расширяем jQuery



Добавляем приведенный ниже код на те страницы, на которых хотим использовать :regex-селектор.

jQuery.expr[':'].regex = function(elem, index, match) {
    var matchParams = match[3].split(','),
        validLabels = /^(data|css):/,
        attr = {
            method: matchParams[0].match(validLabels) ? 
                        matchParams[0].split(':')[0] : 'attr',
            property: matchParams.shift().replace(validLabels,'')
        },
        regexFlags = 'ig',
        regex = new RegExp(matchParams.join('').replace(/^\s+|\s+$/g,''), regexFlags);
    return regex.test(jQuery(elem)[attr.method](attr.property));
}


Использование :regex



// Выберет все DIVы с классами, содержащими числа:

$('div:regex(class,[0-9])');


// Выберет все SCRIPT тэги с параметром SRC содержащую строку jQuery:

$('script:regex(src,jQuery)');


// Выберет все элементы с параметром width между 100 и 300:

$(':regex(css:width, ^[1-3]\\d{2}px$)');


Внимание! Вместо одиночного backslash'a, нужно использовать двойной backslash, например \\d, \\S, \\/, \\.
Tags:
Hubs:
Total votes 56: ↑48 and ↓8+40
Comments10

Articles