I need to run a jquery only if the bold element contains particular text. What am I doing wrong?
Besides using single quotes inside single quotes, which breaks the string, you're using a jQuery selector inside an if statement. This selector only filters your b
tags to those which contain "Choose a sub category"; and then returns a list of those elements. It does not return a boolean. Instead, use the .contains()
method, like so:
if($("b").contains("Choose a sub category")) {
// do stuff
}
You can read more here
EDIT: since the .contains()
method appears to be deprecated, here's a pure JS solution:
var el = document.getElementById("yourTagId") // or something like document.getElementsByTagName("b")[0] if you don't want to add an ID.
if (el.innerHTML.indexOf("Choose a sub category") !== -1) {
// do stuff
}
if ($("b").has(":contains('Choose a sub category:')").length) {
/*Your Stuff Here*/
}
I have always used this to determine if an element exists:
if ($('b:contains("Choose a sub category:")').length > 0) { /*do things*/}