Maison >interface Web >tutoriel CSS >Comment puis-je localiser des éléments avec plusieurs noms de classe dans Selenium ?

Comment puis-je localiser des éléments avec plusieurs noms de classe dans Selenium ?

DDD
DDDoriginal
2024-11-16 22:14:031017parcourir

How Can I Locate Elements with Multiple Class Names in Selenium?

Stratégies de localisation pour les éléments avec plusieurs noms de classe

L'identification d'éléments Web avec plusieurs noms de classe peut présenter un défi lors de l'utilisation de certains localisateurs qui nécessitent un valeur unique séparée par des espaces, telle que l'annotation @FindBy en Java. Pour résoudre ce problème, envisagez les stratégies alternatives suivantes :

Localisateurs XPath

Les expressions XPath offrent une flexibilité dans la mise en correspondance d'éléments en fonction de plusieurs attributs, y compris les noms de classe. Les stratégies suivantes peuvent être utilisées :

  • Correspondance exacte : Cette approche identifie les éléments correspondant exactement aux noms de classe spécifiés dans l'ordre souhaité.
driver.findElement(By.xpath("//div[@class='value test']"));
  • Contains Constraint : Cette stratégie trouve les éléments contenant les noms de classe spécifiés, quel que soit leur order.
driver.findElement(By.xpath("//div[contains(@class, 'value test')]"));
  • Contraintes contenant plusieurs : Pour faire correspondre les éléments avec les deux noms de classe, utilisez l'opérateur et :
driver.findElement(By.xpath("//div[contains(@class, 'value') and contains(@class, 'test')]"));

Sélecteurs CSS

Les sélecteurs CSS offrent une autre option pour sélectionner des éléments avec plusieurs noms de classe :

  • Correspondance exacte : Semblable à XPath, ce sélecteur identifie les éléments correspondant aux noms de classe spécifiés dans l'ordre souhaité.
driver.findElement(By.cssSelector("div[class='value test']"));
  • Contient une sous-chaîne : Ce sélecteur recherche les éléments avec un nom de classe contenant le spécifié sous-chaîne :
driver.findElement(By.cssSelector("div[class*='value test']"));
  • Combinaison de classes : Pour rechercher des éléments avec plusieurs noms de classe, utilisez l'opérateur point (.) pour les combiner :
driver.findElement(By.cssSelector("div.value.test"));

Considérations supplémentaires

Lorsque vous utilisez plusieurs noms de classe, faites attention à ce qui suit :

  • L'ordre des noms de classe peut avoir un impact sur les résultats de correspondance pour les localisateurs de correspondance exacte.
  • Les localisateurs XPath ont tendance à être plus lents que les sélecteurs CSS en général.
  • Les sélecteurs CSS peuvent ne pas être pris en charge par tous les navigateurs Web.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn