vérifier si cet élément OU cet élément est planait avec jQuery

J'ai deux éléments distincts dans mon DOM qui exigent un changement lorsque l'un des deux est a plané. Lorsque le lien est a plané, l'image src doit changer (facile) ET la couleur du lien qui doit changer. Lorsque l'image est planait, le même effet doit se produire (image src changements & créer un lien entre les changements de couleur)

C'est en fait assez facile à faire, mais j'ai le sentiment qu'il y est un moyen BEAUCOUP plus facile de le faire, puis l'approche que je prends. Actuellement, je suis allez à travers chacun des 8 éléments et les tests s'ils sont planait individuellement. Cela fonctionne bien, mais il y a tellement plus de jQuery ici que j'ai le sentiment qu'il devrait être.

J'ai essayé d'ajouter l'attribut onmouseover à la fois des éléments de déclenchement et de la même fonction, mais la fonction n'était pas de déclenchement.

Est-il un moyen de tester si l'élément est planait et déclencher une fonction si l'on est? Quelque chose comme ceci:

if($(#elm1).hover() || $('#elm2').hover()) {
    //effect here
}

OU

if($('#elm1').is(':hover') || $('#elm2').is(':hover')) {
    //effect here
}

J'ai essayé mon code d'exemple ci-dessus, mais n'était pas d'obtenir des résultats. Est-il un moyen de faire ceci ou suis-je coincé avec la vérification de chaque élément?

var isHovered = $('#elem').is(":hover"); pour return boolean
pourquoi ne pas vous ajouter une classe comme hovered lorsque vous ne hover() et vérifier .hovered 🙂
Parce que je suppose que jQuery déjà de magasins d'état, rendant le double de ne rien faire de bon
le var isHovered chose ne fonctionne pas parce que j'ai encore de vérifier les 8 différents éléments individuellement avec qui. Je suis en train de vérifier le lien et l'image, dans la même fonction.

OriginalL'auteur Ty Bailey | 2013-11-19