Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Translate createRef.md to Portuguese #1053

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
48 changes: 24 additions & 24 deletions src/content/reference/react/createRef.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,13 @@ title: createRef

<Pitfall>

`createRef` is mostly used for [class components.](/reference/react/Component) Function components typically rely on [`useRef`](/reference/react/useRef) instead.
`createRef` é usado principalmente para [componentes de classe.](/reference/react/Component) Componentes de função normalmente dependem de [`useRef`](/reference/react/useRef) em vez disso.

</Pitfall>

<Intro>

`createRef` creates a [ref](/learn/referencing-values-with-refs) object which can contain arbitrary value.
`createRef` cria um objeto [ref](/learn/referencing-values-with-refs) que pode conter um valor arbitrário.

```js
class MyInput extends Component {
Expand All @@ -25,11 +25,11 @@ class MyInput extends Component {

---

## Reference {/*reference*/}
## Referência {/*reference*/}

### `createRef()` {/*createref*/}

Call `createRef` to declare a [ref](/learn/referencing-values-with-refs) inside a [class component.](/reference/react/Component)
Chame `createRef` para declarar um [ref](/learn/referencing-values-with-refs) dentro de um [componente de classe.](/reference/react/Component)

```js
import { createRef, Component } from 'react';
Expand All @@ -40,31 +40,31 @@ class MyComponent extends Component {
// ...
```

[See more examples below.](#usage)
[Veja mais exemplos abaixo.](#usage)

#### Parameters {/*parameters*/}
#### Parâmetros {/*parameters*/}

`createRef` takes no parameters.
`createRef` não recebe parâmetros.

#### Returns {/*returns*/}
#### Retorna {/*returns*/}

`createRef` returns an object with a single property:
`createRef` retorna um objeto com uma única propriedade:

* `current`: Initially, it's set to the `null`. You can later set it to something else. If you pass the ref object to React as a `ref` attribute to a JSX node, React will set its `current` property.
* `current`: Inicialmente, é definido como `null`. Você pode, mais tarde, defini-lo para outra coisa. Se você passar o objeto ref para React como um atributo `ref` para um nó JSX, React definirá sua propriedade `current`.

#### Caveats {/*caveats*/}
#### Ressalvas {/*caveats*/}

* `createRef` always returns a *different* object. It's equivalent to writing `{ current: null }` yourself.
* In a function component, you probably want [`useRef`](/reference/react/useRef) instead which always returns the same object.
* `const ref = useRef()` is equivalent to `const [ref, _] = useState(() => createRef(null))`.
* `createRef` sempre retorna um objeto *diferente*. É equivalente a escrever `{ current: null }` sozinho.
* Em um componente de função, você provavelmente deseja [`useRef`](/reference/react/useRef) em vez disso, que sempre retorna o mesmo objeto.
* `const ref = useRef()` é equivalente a `const [ref, _] = useState(() => createRef(null))`.

---

## Usage {/*usage*/}
## Uso {/*usage*/}

### Declaring a ref in a class component {/*declaring-a-ref-in-a-class-component*/}
### Declarando um ref em um componente de classe {/*declaring-a-ref-in-a-class-component*/}

To declare a ref inside a [class component,](/reference/react/Component) call `createRef` and assign its result to a class field:
Para declarar um ref dentro de um [componente de classe,](/reference/react/Component) chame `createRef` e atribua seu resultado a um campo de classe:

```js {4}
import { Component, createRef } from 'react';
Expand All @@ -76,7 +76,7 @@ class Form extends Component {
}
```

If you now pass `ref={this.inputRef}` to an `<input>` in your JSX, React will populate `this.inputRef.current` with the input DOM node. For example, here is how you make a button that focuses the input:
Se agora você passar `ref={this.inputRef}` para um `<input>` em seu JSX, React preencherá `this.inputRef.current` com o nó DOM de entrada. Por exemplo, aqui está como você faz um botão que foca na entrada:

<Sandpack>

Expand Down Expand Up @@ -107,17 +107,17 @@ export default class Form extends Component {

<Pitfall>

`createRef` is mostly used for [class components.](/reference/react/Component) Function components typically rely on [`useRef`](/reference/react/useRef) instead.
`createRef` é usado principalmente para [componentes de classe.](/reference/react/Component) Componentes de função normalmente dependem de [`useRef`](/reference/react/useRef) em vez disso.

</Pitfall>

---

## Alternatives {/*alternatives*/}
## Alternativas {/*alternatives*/}

### Migrating from a class with `createRef` to a function with `useRef` {/*migrating-from-a-class-with-createref-to-a-function-with-useref*/}
### Migrando de uma classe com `createRef` para uma função com `useRef` {/*migrating-from-a-class-with-createref-to-a-function-with-useref*/}

We recommend using function components instead of [class components](/reference/react/Component) in new code. If you have some existing class components using `createRef`, here is how you can convert them. This is the original code:
Recomendamos o uso de componentes de função em vez de [componentes de classe](/reference/react/Component) em código novo. Se você tiver alguns componentes de classe existentes usando `createRef`, aqui está como você pode convertê-los. Este é o código original:

<Sandpack>

Expand Down Expand Up @@ -146,7 +146,7 @@ export default class Form extends Component {

</Sandpack>

When you [convert this component from a class to a function,](/reference/react/Component#alternatives) replace calls to `createRef` with calls to [`useRef`:](/reference/react/useRef)
Quando você [converte este componente de uma classe para uma função,](/reference/react/Component#alternatives) substitua as chamadas para `createRef` por chamadas para [`useRef`:](/reference/react/useRef)

<Sandpack>

Expand All @@ -171,4 +171,4 @@ export default function Form() {
}
```

</Sandpack>
</Sandpack>