Skip to content

Commit

Permalink
Over-translation
Browse files Browse the repository at this point in the history
Translation is different from other pages
  • Loading branch information
ogasawara-k authored and mfuji09 committed Jan 17, 2025
1 parent 65ee0fd commit ae6359f
Showing 1 changed file with 4 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ import { useRef, useState } from "react";

`useRef()` は、単一のプロパティ `current` を持つオブジェクトを作成します。参照には任意の値を格納でき、後でその値を見ていくことができます。 さらに、 DOM 要素への参照を格納することもでき、まさにこれから行うのがそれです。

次に、`Todo()` 関数内の `useState()` フックの下に、 2 つの新しい定数を作成します。それぞれの定数は参照であるべきです。 1 つはビューテンプレートの「編集」ボタン用、もう 1 つは編集テンプレートの編集フィールド用です。
次に、`Todo()` 関数内の `useState()` フックの下に、 2 つの新しい定数を作成します。それぞれの定数は参照であるべきです。 1 つはビューテンプレートの "Edit" ボタン用、もう 1 つは編集テンプレートの編集フィールド用です。

```jsx
const editFieldRef = useRef(null);
Expand Down Expand Up @@ -170,9 +170,9 @@ useEffect(() => {

これらの変更により、`isEditing` が true の場合、React は `editFieldRef` の現在の値を読み取り、ブラウザーのフォーカスがそこに移されるようになります。また、 2 つ目の引数として配列を `useEffect()` に渡します。 この配列は、`useEffect()` が依存すべき値のリストです。 これらの値が含まれている場合、 `useEffect()` はそれらの値のいずれかが変更された場合にのみ実行されます。 私たちは、 `isEditing` の値が変更された場合にのみフォーカスを変更したいのです。

試してみましょう。 <kbd>Tab</kbd> キーを使用して「編集」ボタンのいずれかに移動し、<kbd>Enter</kbd> キーを押します。 `<Todo />` 部分が編集テンプレートに切り替わり、ブラウザーのフォーカスインジケーターが `<input>` 要素の周りに現れるはずです。
試してみましょう。 <kbd>Tab</kbd> キーを使用して "Edit" ボタンのいずれかに移動し、<kbd>Enter</kbd> キーを押します。 `<Todo />` 部分が編集テンプレートに切り替わり、ブラウザーのフォーカスインジケーターが `<input>` 要素の周りに現れるはずです。

### フォーカスを編集ボタンに戻す
### フォーカスを "Edit" ボタンに戻す

一見すると、編集が保存されたり取り消されたりした際に、 React が "Edit" ボタンにフォーカスを戻すようにするのは、簡単そうに見えます。確かに、 `isEditing``false` の場合に、 `useEffect` に条件を追加して編集ボタンにフォーカスを当てることはできますか? それでは、これで試してみましょう。 `useEffect()` の呼び出しを次のように更新してください。

Expand Down Expand Up @@ -258,7 +258,7 @@ useEffect(() => {

これで `useEffect()` のロジックが `wasEditing` に依存することになるので、依存性の配列にそれを指定しました。

キーボードを使用して、`<Todo />` 部分の「編集」と「取り消される可能性」ボタンをアクティブにしてみてください。この章の始めに説明した問題がなく、ブラウザーのフォーカスインジケーターが適切に移されるのがわかるでしょう。
キーボードを使用して、`<Todo />` 部分の "Edit" と "Cancel" ボタンをアクティブにしてみてください。この章の始めに説明した問題がなく、ブラウザーのフォーカスインジケーターが適切に移されるのがわかるでしょう。

## ユーザーがタスクを削除する際にフォーカス

Expand Down

0 comments on commit ae6359f

Please sign in to comment.