Селектор атрибутов-значений без учета регистра c Jquery

мне нужно получить значение

3 ответов


вы можете использовать функцию фильтра jquery так

var meta = $('meta[name]').filter(function() {
    return this.name.toLowerCase() == 'somekindofid';
});

на основе CSS selector case нечувствителен к атрибутам

http://jsfiddle.net/nickywaites/mkBvC/


кроме того, для нечувствительного к регистру атрибута * = селектор:

$("meta[name*=someKindOfId]")

Вы можете использовать:

$('meta').filter(function() {
       return (/somekindofid/i).test($(this).attr('name'));
}).attr("content")

как насчет этого?

вы можете использовать с учетом регистра выражение jQuery, как показано в фрагменте ниже (выполните его, чтобы увидеть, как первый div соответствует, а второй нет).

$.expr[':'].iAttrContains = function(node, stackIndex, properties){
    var args = properties[3].split(',').map(function(arg) {
        return arg.replace(/^\s*["']|["']\s*$/g, '');  
    });
    if ($(node).attr(args[0])) {
        //exact match:
        return $(node).attr(args[0]).toLowerCase() == args[1].toLowerCase();
        //if you actually prefer a "contains" behavior:
        //return -1 !== $(node).attr(args[0]).toLowerCase().indexOf(args[1].toLowerCase());
    }
};

$("div:iAttrContains('data-name', 'test')").addClass('matched');
div{background:red;}
div.matched{background:green;}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>

<div data-name="This is a test">First div</div>
<div data-name="This is a div">Second div</div>