Um seletor de elemento é uma expressão CSS que pode identificar um ou mais elementos.
Você pode encontrar informações básicas sobre os seletores de CSS no documento Seletores no site Mozilla Developer Network (MDN).
Você pode definir se deseja usar elemento em classes ou ID de elemento nas suas preferências de conta. Clique em Administração > Visual Experience Composer, em seguida, escolha seus seletores de CSS preferidos.
As Classes de elementos estão disponíveis como seletores em atividades de Teste A/B, Personalização automatizada e Teste multivariado.
Para obter informações sobre quando usar seletores de CSS e quando usar IDs exclusivas, consulte Práticas recomendadas e limitações do Visual Experience Composer.
O Target usa um algoritmo simples para criar um seletor. Esta é uma breve explicação da lógica de geração:
Se um elemento tiver uma id, por exemplo id="container"
, o seletor do elemento é #container
.
Por exemplo:
<div class="wrapper">
<div id="container"> <!-- Selector is computed for this element -->
<ul class="navigation">
<li class="item active"> Home </li>
<li class="item"> Men </li>
<li class="item"> Women </li>
<li class="item"> Kids </li>
</ul>
</div>
</div>
Se um elemento contiver um atributo de classe, o Target tentará utilizar a primeira classe de qualquer classe presente no elemento.
O Target tenta analisar o elemento pai até encontrar o elemento <HTML>
ou um elemento com uma id. Sempre que um elemento contiver uma id e o seletor for calculado no elemento filho descendente, a ID desse elemento contribuirá para o seletor.
Por exemplo:
<div class="wrapper">
<div id="container"> <!-- id is present here. It contributes to selector -->
<ul class="navigation">
<li class="item active"> Home </li> <!-- Selector is computed for this element -->
<li class="item"> Men </li>
<li class="item"> Women </li>
<li class="item"> Kids </li>
</ul>
</div>
</div>
Neste exemplo:
Seletor: #container
> ul.navigation:eq(0)
> li.item:eq(0)
(" > " indica o filho imediato.)
eq
informa ao índice que há um elemento com "tagName = UL" e a primeira classe é navigation
. Portanto, index
é 0. Consulte o artigo Seletores no site MDN para obter mais informações.
Se um elemento não contiver uma classe, o Target usará tagName
para o elemento e navegará pelo elemento pai até que o elemento <HTML>
ou um elemento com uma id seja encontrado.
Por exemplo:
<div class="wrapper">
<div id="container"> <!-- id is present here. It contributes to selector -->
<ul class="navigation">
<li> Home </li>
<li> Men </li>
<li class="active"> Women </li>
<li> Kids </li><!-- Selector is computed for this element -->
</ul>
</div>
</div>
Seletor: #container
> ul.navigation(0)
> li:nth-of-type(4)
Saiba mais sobre nth-of-type na página da Web de Dicas de CSS.
No processo acima: