Поиск элемента с определенным свойством и значением css

Приветствую. Мне нужно найти элемент на странице со свойством left: 5px. Этот код не помогает. Что не правильно?
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .javascript.geshi_code {font-family:monospace;} .javascript.geshi_code .imp {font-weight: bold; color: red;} .javascript.geshi_code .kw1 {color: #000066; font-weight: bold;} .javascript.geshi_code .kw2 {color: #003366; font-weight: bold;} .javascript.geshi_code .kw3 {color: #000066;} .javascript.geshi_code .co1 {color: #006600; font-style: italic;} .javascript.geshi_code .co2 {color: #009966; font-style: italic;} .javascript.geshi_code .coMULTI {color: #006600; font-style: italic;} .javascript.geshi_code .es0 {color: #000099; font-weight: bold;} .javascript.geshi_code .br0 {color: #009900;} .javascript.geshi_code .sy0 {color: #339933;} .javascript.geshi_code .st0 {color: #3366CC;} .javascript.geshi_code .nu0 {color: #CC0000;} .javascript.geshi_code .me1 {color: #660066;} .javascript.geshi_code span.xtra { display:block; }

$('p[style="left: 5px;"]');
 

Находит элемент, даже если значение свойства left: 0px. Почему так?

1 ответов


Если элемент получает css-свойство через файл стилей, то оно не будет записано в атрибут. В атрибут style пишутся только css-свойства, изменяемые с помощью js.

Ну и вы же понимаете, что вы просто сравниваете две строки, и если в записи атрибута не будет например пробела или точки с запятой, то равенства не будет.

В общем, то, что вы делаете, наверняка не то, что вам реально нужно. Если каким-то образом js изменил css-свойство этого элемента, значит, до элемента можно достучаться вновь. Добавьте класс или data-атрибут, но только ни в коем случае не определяйте элемент по значению его атрибута style.