freeCodeCamp/curriculum/challenges/portuguese/03-front-end-libraries/react/add-inline-styles-in-react.md

3.5 KiB

id title challengeType forumTopicId dashedName
5a24c314108439a4d4036182 Adicione estilos em linha no React 6 301378 add-inline-styles-in-react

--description--

Você pode ter percebido no último desafio que existem diversas outras diferenças de sintaxe de estilos HTML em linha em adição ao atributo style definido para um objeto JavaScript. Primeiro, os nomes de certas propriedades de estilo CSS usam camel case. Por exemplo, o último desafio definiu o tamanho da fonte com fontSize ao invés de font-size. Palavras com hifens como font-size são sintaxes inválidas para propriedades de objeto JavaScript, então React usa camel case. Como regra, qualquer propriedades de estilos com hífen são escritas usando camel case em JSX.

Todas as unidades de valor de comprimento das propriedades (como height,width, e fontSize) são assumidos para estar em px a não ser que seja especificado outra forma. Se você quiser usar em, por exemplo, você envolve o valor e as unidades em aspas, como {fontSize: "4em"}. Além dos valores de comprimento que tem como padrão px, todas os outros valores de propriedade devem estar entre aspas.

--instructions--

Se você tem um grande conjunto de estilos, você pode atribuir um objeto de estilo para uma constante para te ajudar a manter o código organizado. Declare suas constantes de estilo como variáveis globais no topo do arquivo. Inicialize a constante styles e atribua um object com três propriedades de estilo e os seus valores à constante. Dê a div a color (cor) purple (roxo), um font-size (tamanho de fonte) de 40 e um border (borda) de 2px solid purple. Em seguida, defina o atributo style para ser igual a constante styles.

--hints--

A variável styles deve ser um objeto com três propriedades.

assert(Object.keys(styles).length === 3);

A variável styles devem ter a propriedade color definida com o valor purple.

assert(styles.color === 'purple');

A variável styles devem ter a propriedade fontSize definida com o valor 40.

assert(styles.fontSize === 40);

A variável styles deve ter a propriedade border definida com o valor 2px solid purple.

assert(styles.border === '2px solid purple');

O componente deve renderizar um elemento div.

assert(
  (function () {
    const mockedComponent = Enzyme.shallow(React.createElement(Colorful));
    return mockedComponent.type() === 'div';
  })()
);

O elemento div deve ter seu estilo definido pelo objeto styles.

assert(
  (function () {
    const mockedComponent = Enzyme.shallow(React.createElement(Colorful));
    return (
      mockedComponent.props().style.color === 'purple' &&
      mockedComponent.props().style.fontSize === 40 &&
      mockedComponent.props().style.border === '2px solid purple'
    );
  })()
);

--seed--

--after-user-code--

ReactDOM.render(<Colorful />, document.getElementById('root'))

--seed-contents--

// Change code above this line
class Colorful extends React.Component {
  render() {
    // Change code below this line
    return (
      <div style={{color: "yellow", fontSize: 24}}>Style Me!</div>
    );
    // Change code above this line
  }
};

--solutions--

const styles = {
  color: "purple",
  fontSize: 40,
  border: "2px solid purple"
};
// Change code above this line
class Colorful extends React.Component {
  render() {
    // Change code below this line
    return (
      <div style={styles}>Style Me!</div>
    );
    // Change code above this line
  }
};