Skip to content

Uma longa lista de perguntas (básicas e avançadas) sobre CSS e suas explicações ✨

License

Notifications You must be signed in to change notification settings

jaimeneeves/css-questions

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

79 Commits
 
 
 
 

Repository files navigation

Perguntas Básicas e Avançadas sobre CSS

Bem-vindos ao nosso repositório GitHub, um tesouro de perguntas sobre CSS que vão do básico ao avançado! 💪🚀 Se você está começando a aprender CSS ou já é um desenvolvedor experiente procurando um desafio, você veio ao lugar certo. Este repositório foi criado com um único objetivo em mente: ajudá-lo a testar, refinar e expandir seu conhecimento de CSS de uma maneira divertida e engajadora.

Então, se você está pronto para embarcar nesta jornada de aprendizado, comece a explorar as perguntas, teste suas habilidades e divirta-se no processo. Boa sorte e esperamos que você aproveite tanto quanto nós ao criar e atualizar este repositório! ❤️

Sinta-se à vontade para entrar em contato comigo! 😊


Básicas

1. Qual propriedade CSS altera a cor de fundo de um elemento?
  • A) background-color
  • B) color
  • C) bgcolor
  • D) background-image
Resposta

Resposta: A) background-color

A propriedade CSS background-color é usada especificamente para definir a cor de fundo de um elemento HTML. Esta propriedade aceita valores de cor, como nomes de cores (por exemplo, red), valores HEX (por exemplo, #FF0000), valores RGB (por exemplo, rgb(255, 0, 0)), e mais.


2. O que a propriedade z-index controla no CSS?
  • A) Tamanho do elemento
  • B) Cor do elemento
  • C) Posição do elemento
  • D) Nenhum dos anteriores
Resposta

Resposta: C) Posição do elemento

z-index Controla a sobreposição dos elementos, determinando qual elemento aparece na frente de outro quando eles se sobrepõem.


3. Como você faria para aplicar um estilo somente ao primeiro parágrafo dentro de um <div>?
  • A) div p:first-child { ... }
  • B) div p:first-of-type { ... }
  • C) div:first p { ... }
  • D) div p:first { ... }
Resposta

Resposta: B) div p:first-of-type { ... }

A pseudo-classe :first-of-type é usada para selecionar o primeiro elemento de um tipo específico dentro de seu container. No contexto desta pergunta, div p:first-of-type { ... } seleciona o primeiro elemento <p> dentro de qualquer <div>, aplicando estilos apenas a esse parágrafo.

Exemplo Prático:

div p:first-of-type {
  background-color: yellow;  /* Define a cor de fundo como amarela */
  margin-bottom: 20px;       /* Adiciona uma margem inferior de 20px */
}
<div>
  <p>Este é o primeiro parágrafo e ele será amarelo com margem maior.</p>
  <p>Este é o segundo parágrafo e não terá os estilos aplicados.</p>
</div>
<div>
  <p>Outro primeiro parágrafo, também estilizado como o primeiro do bloco anterior.</p>
  <p>Este é outro segundo parágrafo sem os estilos especiais.</p>
</div>


4. Como você faria uma borda pontilhada?
  • A) border-style: dotted;
  • B) border-line: dots;
  • C) border: dots;
  • D) style: dotted;
Resposta

Resposta: A) border-style: dotted;

Para criar uma borda pontilhada, você deve usar border-style: dotted;.


5. Qual valor de position é usado para sobrepor elementos?
  • A) static;
  • B) fixed;
  • C) absolute;
  • D) relative;
Resposta

Resposta: C) absolute;

O position: absolute; permite que um elemento seja posicionado em relação ao seu contêiner mais próximo não estático, podendo sobrepor outros elementos.


6. Qual propriedade CSS é usada para criar espaçamento entre as bordas de dois elementos adjacentes?
  • A) margin
  • B) padding
  • C) border
  • D) spacing
Resposta

Resposta: A) margin

A propriedade CSS margin é usada para criar espaço ao redor dos elementos, fora de quaisquer bordas definidas. Ela é eficaz para controlar o espaçamento entre elementos adjacentes, garantindo que haja uma separação visual entre eles sem alterar o espaço interno do elemento, o qual é controlado pela propriedade padding.

Vamos analisar as outras opções para entender por que são incorretas:

b) padding - Esta propriedade adiciona espaço dentro de um elemento, entre o conteúdo e a borda, e não afeta o espaçamento entre elementos adjacentes.

c) border - Define a borda ao redor do elemento, mas não cria espaço entre elementos.

d) spacing - Não é uma propriedade CSS válida.


7. Qual propriedade CSS controla o tamanho da fonte?
  • A) font-size
  • B) text-size
  • C) font-weight
  • D) text-style
Resposta

Resposta: A) font-size

A propriedade CSS font-size é usada especificamente para definir o tamanho da fonte de um texto dentro de um elemento HTML. Ela pode ser definida usando diferentes unidades de medida como pixels (px), pontos (pt), ems (em), porcentagens (%), entre outros.


8. Qual propriedade CSS controla a visibilidade de um elemento?
  • A) visibility
  • B) display
  • C) opacity
  • D) view
Resposta

Resposta: A) visibility

A propriedade CSS visibility é usada para controlar a visibilidade de um elemento na página. Os valores possíveis incluem visible (o padrão, que torna o elemento visível), hidden (que esconde o elemento, mas ainda ocupa espaço na página), e collapse (usado principalmente com tabelas para ocultar linhas ou colunas).

Vamos considerar também as outras opções:

b) display - Esta propriedade controla se um elemento é exibido ou não, incluindo como ele é renderizado na página. Valores como none podem fazer um elemento desaparecer completamente, diferentemente de visibility, onde o espaço ainda é ocupado.

c) opacity - Controla a transparência de um elemento. Um valor de 0 faz o elemento ficar totalmente transparente, mas ainda interativo e ocupando espaço.

d) view - Não é uma propriedade CSS válida.


9. Qual propriedade CSS ajusta o espaço entre caracteres?
  • A) letter-spacing
  • B) word-spacing
  • C) text-spacing
  • D) space-between
Resposta

Resposta: A) letter-spacing

A propriedade CSS letter-spacing é usada para ajustar o espaço entre os caracteres de um texto. Isso permite um controle mais fino sobre a aparência do texto, podendo melhorar a legibilidade ou criar um efeito visual específico. A propriedade aceita valores como normal (o padrão), ou uma medida específica (por exemplo, 2px, -1px).

Vamos analisar as outras opções:

b) word-spacing - Esta propriedade ajusta o espaço entre palavras, não entre caracteres.

c) text-spacing - Não é uma propriedade válida em CSS.

d) space-between - Embora seja um valor que pode ser usado em propriedades como justify-content para espaçamento entre itens flexíveis ou de grade, não é usado para ajustar espaçamento entre caracteres.


10. Qual propriedade CSS permite animar a transição entre estados?
  • A) animation
  • B) transition
  • C) transform
  • D) animate
Resposta

Resposta: B) transition

A propriedade CSS transition é usada para animar mudanças de propriedades de CSS ao longo do tempo, como cor, tamanho, posição, entre outras. Isso permite que as mudanças de estilo não ocorram instantaneamente, mas sim gradualmente durante um período de tempo especificado, criando uma experiência visual suave e agradável.

Aqui está o que cada uma das outras opções significa:

a) animation - Embora também usada para animações, a propriedade animation é mais complexa e geralmente é usada em conjunto com @keyframes para definir animações detalhadas que incluem múltiplos estados e timings.

c) transform - Esta propriedade é usada para aplicar transformações geométricas a um elemento (como rotação, escala, movimento, inclinação), mas por si só não cria uma animação ao longo do tempo.

d) animate - Não é uma propriedade CSS válida.


11. Qual propriedade CSS é usada para controlar a largura de um elemento?
  • A) width
  • B) length
  • C) size
  • D) dimension
Resposta

Resposta: A) width

A propriedade width em CSS é usada para definir a largura de um elemento. Ela pode ser especificada em várias unidades de medida, como pixels (px), porcentagens (%), ems (em), entre outras. Essa propriedade é fundamental para o layout e dimensionamento de elementos na web.

Exemplo Prático:

Suponha que você queira definir a largura de uma

para 300 pixels:

.fixed-width {
  width: 300px; /* Define a largura da div para 300 pixels */
}
<div class="fixed-width">Conteúdo com largura fixa.</div>


12. Qual propriedade CSS é usada para adicionar uma borda ao redor de um elemento?
  • A) border
  • B) edge
  • C) frame
  • D) outline
Resposta

Resposta: A) border

A propriedade CSS border é usada para adicionar uma borda ao redor de elementos. Você pode especificar o estilo, a largura e a cor da borda, usando valores como 1px solid black para uma borda sólida de 1 pixel de espessura na cor preta.

Exemplo Prático:

Suponha que você deseja adicionar uma borda azul sólida de 2 pixels ao redor de uma <div>:

.blue-border {
  border: 2px solid blue; /* Adiciona uma borda azul sólida de 2px */
}
<div class="blue-border">
  Este bloco tem uma borda azul.
</div>


13. Qual propriedade CSS define a altura de um elemento?
  • A) height
  • B) length
  • C) size
  • D) altitude
Resposta

Resposta: A) height

A propriedade CSS height é usada para definir a altura de um elemento. Ela pode ser especificada em várias unidades, como pixels (px), porcentagens (%), vh (viewport height), entre outras. Esta propriedade é fundamental para controlar o layout e o dimensionamento dos elementos em uma página web.

Exemplo Prático:

Suponha que você deseja definir a altura de uma <div> para 150 pixels:

.fixed-height {
  height: 150px; /* Define a altura como 150 pixels */
}
<div class="fixed-height">
  Esta div tem uma altura fixa de 150 pixels.
</div>

Neste exemplo, a <div class="fixed-height"> terá uma altura fixa de 150 pixels.


14. Qual propriedade CSS ajusta a largura da borda de um elemento?
  • A) border-width
  • B) border-size
  • C) border-length
  • D) border-scale
Resposta

Resposta: A) border-width

A propriedade CSS border-width é usada para especificar a largura das bordas de um elemento. Você pode definir um valor único para todas as bordas ou especificar valores individuais para cada borda (superior, direita, inferior, esquerda).

Exemplo Prático:

Suponha que você deseja definir a largura da borda de uma <div> para ser mais espessa no topo e na base, mas mais fina nas laterais:

.custom-border {
  border-style: solid;
  border-color: black;
  border-width: 8px 2px; /* 8px no topo e na base, 2px nas laterais */
}
<div class="custom-border">
  Esta div tem bordas de larguras personalizadas.
</div>

Neste exemplo, a <div class="custom-border"> terá bordas superiores e inferiores com 8 pixels de largura, e bordas laterais com 2 pixels de largura.

15. Qual seletor CSS é usado para estilizar todos os parágrafos dentro de um elemento com a classe 'texto'?
  • A) .texto p
  • B) p .texto
  • C) #texto p
  • D) p > .texto
Resposta

Resposta: A) .texto p

O seletor .texto p seleciona todos os elementos <p> que são descendentes de qualquer elemento que tenha a classe texto. Isso significa que todos os parágrafos dentro de um contêiner com a classe texto serão estilizados.

.texto p {
  color: blue;  /* Cor do texto azul */
  font-size: 16px; /* Tamanho do texto 16px */
}
<div class="texto">
  <p>Este parágrafo será azul e com tamanho 16px.</p>
  <p>Este também será azul e com tamanho 16px.</p>
</div>


16. Qual propriedade define a direção do layout flexbox para uma linha de elementos?
  • A) flex-direction: row
  • B) flex-direction: column
  • C) direction: flex
  • D) row-direction: flex
Resposta

Resposta: A) flex-direction: row

A propriedade flex-direction: row define a direção do layout flexbox para uma linha de elementos. Isso significa que os elementos serão dispostos lado a lado, como em uma linha horizontal.

Exemplo Prático:

Imagine que você deseja criar um menu horizontal com itens lado a lado. Para isso, você pode usar o seguinte código CSS3:

.menu {
  display: flex;
  flex-direction: row;
}

.menu li {
  padding: 10px;
  border: 1px solid #ccc;
}

Nesse exemplo, a classe .menu define o layout flexbox com direção em linha. As classes .menu li estilizam cada item do menu com padding e borda.


17. Qual propriedade CSS3 remove o marcador padrão (bolinha ou número) de uma lista não ordenada?
  • A) list-style: none
  • B) no-list
  • C) remove-list
  • D) list-style-type: none
Resposta

Resposta: A) list-style: none

A propriedade list-style: none em CSS3 remove o marcador padrão (bolinha ou número) de uma lista não ordenada (<ul>). Isso permite que você personalize o estilo da sua lista, criando um design mais moderno e atraente.

Exemplo Prático:

Imagine que você deseja criar uma lista com marcadores de estilo "disco" em vez das bolinhas padrão. Para isso, você pode usar o seguinte código CSS3:

ul {
  list-style: disc;
}


18. Qual propriedade controla o espaçamento interno de um elemento?
  • A) margin
  • B) padding
  • C) border
  • D) spacing
Resposta

Resposta: B) padding

A propriedade padding é usada para controlar o espaçamento interno, ou seja, o espaço entre o conteúdo de um elemento e suas bordas.

div {
  padding: 20px;
  background-color: lightgray;
}
<div>Este div tem 20px de padding.</div>


Avançadas

1. Qual propriedade CSS é usada para aplicar uma máscara a um elemento?
  • A) clip-path
  • B) mask-image
  • C) background-clip
  • D) border-mask
Resposta

Resposta: B) mask-image

A propriedade CSS mask-image permite aplicar uma máscara a um elemento. Uma máscara define quais áreas do elemento são visíveis e quais são transparentes, usando uma imagem ou um gradiente. Este recurso é poderoso para criar efeitos visuais complexos em interfaces web.

Vamos analisar as outras opções:

a) clip-path - Embora clip-path também crie áreas visíveis e invisíveis, ele é usado para recortar um elemento em formas específicas, mas não se baseia em imagens ou gradientes para definir a transparência.

c) background-clip - Determina até onde o fundo (como cor ou imagem) deve se estender dentro do elemento, mas não cria uma máscara de transparência.

d) border-mask - Não é uma propriedade CSS válida.


2. Qual propriedade CSS é usada para aplicar múltiplas sombras a um elemento?
  • A) box-shadow
  • B) text-shadow
  • C) multiple-shadow
  • D) shadow-layer
Resposta

Resposta: A) box-shadow e B) text-shadow

As propriedades box-shadow e text-shadow em CSS podem ser usadas para aplicar múltiplas sombras a um elemento, seja ele um contêiner (box-shadow) ou texto (text-shadow). Ambas as propriedades permitem a especificação de múltiplas sombras simplesmente separando-as com vírgulas dentro da mesma declaração. Isso permite a criação de efeitos de profundidade e complexidade visual.

Aqui está o que as outras opções representam:

c) multiple-shadow - Não é uma propriedade CSS válida.

d) shadow-layer - Também não é uma propriedade CSS válida.


3. Qual propriedade CSS define a ordem de empilhamento de um elemento?
  • A) z-index
  • B) stack-index
  • C) order
  • D) layer
Resposta

Resposta: A) z-index

A propriedade CSS z-index é usada para controlar a ordem de empilhamento dos elementos sobrepostos em uma página. Elementos com um maior z-index serão posicionados acima daqueles com um z-index menor. Esta propriedade só tem efeito em elementos cuja posição é definida como algo diferente de static (como relative, absolute, fixed, ou sticky).

Vamos considerar as outras opções:

b) stack-index - Não é uma propriedade CSS válida.

c) order - Esta propriedade é usada dentro de flexbox para controlar a ordem de exibição dos itens flex, mas não afeta a sobreposição de elementos fora de contextos flex.

d) layer - Embora o conceito de camadas seja relevante em design gráfico, layer não é uma propriedade CSS.


4. Qual função CSS é usada para aplicar cores com transparência?
  • A) rgba()
  • B) opacity()
  • C) transparent()
  • D) alpha()
Resposta

Resposta: A) rgba()

A função rgba() em CSS é usada para definir cores com transparência. A sigla RGBA significa Red, Green, Blue, Alpha, onde os três primeiros valores são números que representam a intensidade das cores vermelho, verde e azul, respectivamente, e o último valor (Alpha) representa a transparência da cor. O valor alpha pode ser um número entre 0 (completamente transparente) e 1 (completamente opaco).

Vamos analisar as outras opções:

b) opacity() - Não é uma função, mas uma propriedade que ajusta a transparência de um elemento inteiro, afetando não só a cor, mas todos os conteúdos visuais do elemento.

c) transparent() - Não é uma função. transparent é um valor de cor que pode ser usado para definir uma cor totalmente transparente, mas não permite a especificação de níveis de transparência.

d) alpha() - Não é uma função autônoma em CSS. O componente alpha é usado dentro de outras funções de cor como rgba() e hsla().


5. Qual seletor CSS é usado para estilizar todos os elementos irmãos que seguem um elemento especificado?
  • A) +
  • B) >
  • C) ~
  • D) *
Resposta

Resposta: C) ~

O seletor ~ em CSS, conhecido como seletor de irmãos gerais, é usado para estilizar todos os elementos irmãos que seguem um elemento especificado. Este seletor permite aplicar estilos a todos os irmãos de um mesmo tipo que estão no mesmo nível do DOM e vêm após o elemento especificado.

Exemplo Prático:

Suponha que você tenha um HTML com vários <p> e você quer estilizar todos os <p> que seguem um <h1> específico, mas não os que vêm antes dele. Você poderia usar o seletor ~ da seguinte maneira:

h1 ~ p {
  color: red;
  font-weight: bold;
}
<h1>Titulo Principal</h1>
<p>Este parágrafo não será afetado.</p>
<h1>Segundo Título</h1>
<p>Este parágrafo será estilizado.</p>
<p>Este parágrafo também será estilizado.</p>

Neste exemplo, apenas os parágrafos que seguem o segundo <h1> serão estilizados com texto em vermelho e em negrito. Os parágrafos antes do segundo <h1> ou após outro elemento que não seja um <h1> não serão afetados.


6. Qual propriedade CSS controla o comportamento de rolagem suave?
  • A) scroll-behavior
  • B) overflow-scroll
  • C) scroll-snap
  • D) smooth-scroll
Resposta

Resposta: A) scroll-behavior

A propriedade CSS scroll-behavior é usada para especificar se a rolagem de um contêiner de rolagem deve ser animada de forma suave (smooth) ou instantânea (auto). Este é um ajuste útil para melhorar a experiência do usuário ao navegar por páginas que contêm links de âncora ou ao usar métodos de rolagem programáticos em JavaScript.


7. Qual propriedade CSS permite a criação de colunas para layout de texto?
  • A) column-count
  • B) flex-wrap
  • C) grid-template-columns
  • D) column-layout
Resposta

Resposta: A) column-count

A propriedade CSS column-count é usada para dividir o conteúdo de um elemento em várias colunas, proporcionando um layout similar ao de jornais e revistas. Esta propriedade define o número de colunas desejadas, e o navegador automaticamente distribui o conteúdo entre elas.

.news-article {
  column-count: 3;
  column-gap: 20px;  /* Espaço entre as colunas */
}
<div class="news-article">
  Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vivamus lacinia odio vitae vestibulum.
  Vestibulum lacinia accumsan velit, sit amet vestibulum nunc cursus ut. Sed tincidunt...
</div>


8. Para criar um layout de colunas que automaticamente ajusta o número de colunas baseado na largura do viewport, sem utilizar media queries, qual propriedade CSS você deve usar e com qual valor?
  • A) column-count: auto;
  • B) column-width: 200px;
  • C) flex-basis: 200px;
  • D) grid-auto-flow: column;
Resposta

Resposta: B) column-width: 200px;

A propriedade column-width no CSS é utilizada para especificar a largura mínima das colunas dentro de um elemento com múltiplas colunas. Ao definir esta propriedade, o navegador distribui automaticamente o número de colunas que cabem no contêiner, sem exceder a largura especificada para cada coluna. Isso permite um ajuste automático do número de colunas baseado na largura do viewport, ideal para layouts responsivos.

Exemplo Prático:

Neste exemplo, o contêiner ajusta o número de colunas automaticamente conforme a largura do viewport aumenta ou diminui, tudo isso sem a necessidade de usar media queries.

.container {
  column-width: 200px;
  column-gap: 20px;
  width: 100%;
  height: 300px;
  border: 1px solid #000;
  padding: 10px;
}
<div class="container">
  <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non risus. Suspendisse lectus tortor, dignissim sit amet, adipiscing nec, ultricies sed, dolor. Cras elementum ultrices diam. Maecenas ligula massa, varius a, semper congue, euismod non, mi.</p>
</div>


9. Qual propriedade CSS é usada para aplicar uma transformação 3D a um elemento?
  • A) transform-3d
  • B) transform-style
  • C) perspective
  • D) transform
Resposta

Resposta: D) transform

A propriedade CSS transform permite aplicar transformações 2D ou 3D a um elemento, como rotacionar, escalar, mover ou inclinar. Para transformações 3D, você pode usar funções como rotateX(), rotateY(), rotateZ(), translateZ(), entre outras, que manipulam o elemento no espaço tridimensional.

Exemplo Prático:

Suponha que você deseja aplicar uma rotação 3D em torno do eixo Y para criar um efeito de virada de cartão quando o usuário passa o mouse sobre o elemento:

.card {
  width: 200px;
  height: 100px;
  background-color: #f0f0f0;
  transition: transform 0.5s;
  transform-style: preserve-3d; /* Mantém o estilo 3D */
}

.card:hover {
  transform: rotateY(180deg); /* Rotação em torno do eixo Y */
}
<div class="card">
  Passe o mouse aqui para ver o efeito!
</div>

Neste exemplo, quando o usuário passa o mouse sobre o <div class="card">, ele rotacionará em torno do eixo Y.


10. Qual propriedade CSS é usada para definir a ordem de visualização em uma flexbox?
  • A) flex-order
  • B) flex-index
  • C) order
  • D) flex-sequence
Resposta

Resposta: C) order

A propriedade CSS order é usada dentro de um contêiner Flexbox para controlar a ordem de disposição dos itens flexíveis, independentemente de sua ordem no código HTML. Isso permite ajustar dinamicamente a posição dos elementos na interface do usuário sem alterar o HTML.

Exemplo Prático:

Suponha que você tenha três itens em um contêiner Flexbox e deseja que o terceiro item apareça como o primeiro:

.flex-container {
  display: flex;
}

.first {
  order: -1; /* Faz este item aparecer primeiro */
}
<div class="flex-container">
  <div>Item 1</div>
  <div>Item 2</div>
  <div class="first">Item 3</div>
</div>


11. Qual propriedade CSS3 é usada para aplicar filtros visuais a um elemento?
  • A) filter
  • B) blur
  • C) effect
  • D) visual-filter
Resposta

Resposta: A) filter

A propriedade CSS filter permite aplicar efeitos gráficos como desfoque (blur), saturação (saturate), brilho (brightness), e muitos outros a elementos HTML. Esta propriedade é muito versátil e pode ser usada para criar uma variedade de efeitos visuais sem a necessidade de software de edição de imagens.

.blurry-image {
  filter: blur(5px) contrast(200%);
  transition: filter 0.3s ease;  /* Suaviza a transição dos filtros */
}
.blurry-image:hover {
  filter: none;  /* Remove os filtros ao passar o mouse */
}
<img src="example.jpg" alt="Descriptive Alt Text" class="blurry-image">


About

Uma longa lista de perguntas (básicas e avançadas) sobre CSS e suas explicações ✨

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published