e.g.:
a[href="val"]
Does “val” need to have quotes around it? Single or double are acceptable? What about for integers?
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
TLDR: Quotes are required unless the value meets the identifier specification for CSS2.1
The CSS spec might say they are optional, but the real world presents a different story. When making a comparison against the href attribute you will need to use quotes (single or double work in my very limited testing – latest versions of FF, IE, Chrome.)Interestingly enough the css spec link referenced by @Pekka happens to use quotes around their href-specific examples.
And it’s not just due to non-alpha characters like the period or slashes that give this unique situation a quote requirement – using a partial match selector ~= doesn’t work if you just use the “domain” in “domain.com”
Ok, every answer here is wrong (including my own previous answer.) The CSS2 spec didn’t clarify whether quotes are required in the selector section itself, but the CSS3 spec does and quotes the rule as a CSS21 implementation:
And here is the identifier info:
My answer seemed correct but that’s because the ‘~=’ is a white-space selector comparator so it will never match a partial string inside an href value. A ‘*=’ comparator does work however. And a partial string like ‘domain’ does work for matching href=’www.domain.com’. But checking for a full domain name would not work because it violates the identifier rule.