ホームページ  >  記事  >  ウェブフロントエンド  >  反応の基本

反応の基本

DDD
DDDオリジナル
2024-09-19 06:19:371021ブラウズ

ここでは、主要な React 用語を例とともに説明します。

1.コンポーネント

コンポーネントは React アプリケーションの構成要素です。これは、UI (ユーザー インターフェイス) の一部を返す JavaScript 関数またはクラスです。

機能コンポーネント (最新の React で一般的):

function Welcome(props) {
  return <h1>Hello, {props.name}!</h1>;
}

クラスコンポーネント (古いスタイル):

class Welcome extends React.Component {
  render() {
    return <h1>Hello, {this.props.name}!</h1>;
  }
}

2. JSX (JavaScript XML)

JSX を使用すると、JavaScript 内に HTML のような構文を記述することができます。これは React.createElement() の糖衣構文です。

例:

const element = <h1>Hello, world!</h1>;

JSX is compiled to:

const element = React.createElement('h1', null, 'Hello, world!');

3. Props (プロパティ)

プロップは、あるコンポーネントから別のコンポーネントにデータを渡す方法です。これらは読み取り専用であり、コンポーネントを動的にすることができます。

例:

function Greeting(props) {
  return <h1>Hello, {props.name}!</h1>;
}

<Greeting name="Alice" />

4.状態

State は、動的データを保持し、コンポーネントのレンダリング出力に影響を与える JavaScript オブジェクトです。 setState (クラスコンポーネント) または useState フック (機能コンポーネント) を使用して更新できます。

機能コンポーネントの useState の例:

import { useState } from 'react';

function Counter() {
  const [count, setCount] = useState(0);

  return (
    <div>
      <p>You clicked {count} times</p>
      <button onClick={() => setCount(count + 1)}>Click me</button>
    </div>
  );
}

5.フック

フックは、機能コンポーネントで状態やその他の React 機能を使用できるようにする関数です。

useState: 機能コンポーネントの状態を管理します。
useEffect: 機能コンポーネントで副作用を実行します。

使用効果の例:

import { useState, useEffect } from 'react';

function Timer() {
  const [seconds, setSeconds] = useState(0);

  useEffect(() => {
    const interval = setInterval(() => {
      setSeconds(seconds => seconds + 1);
    }, 1000);

    return () => clearInterval(interval);
  }, []);

  return <h1>{seconds} seconds have passed.</h1>;
}

6.仮想 DOM

仮想 DOM は、実際の DOM の軽量コピーです。 React はこれを使用して変更を追跡し、ページ全体ではなく変更された DOM の部分のみを再レンダリングすることで UI を効率的に更新します。

7.イベント処理

React はイベント ハンドラーに小文字ではなくキャメルケースを使用し、文字列の代わりに関数をイベント ハンドラーとして渡します。

Example:

function ActionButton() {
  function handleClick() {
    alert('Button clicked!');
  }

  return <button onClick={handleClick}>Click me</button>;
}

8.レンダリング

レンダリングは、React が DOM 要素をブラウザーに出力するプロセスです。コンポーネントは、props、state、その他のデータに基づいて UI をレンダリングします。

例:

import ReactDOM from 'react-dom';

function App() {
  return <h1>Hello, React!</h1>;
}

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

9.条件付きレンダリング

条件に基づいてさまざまなコンポーネントや要素をレンダリングできます。

例:

function Greeting(props) {
  const isLoggedIn = props.isLoggedIn;
  return isLoggedIn ? <h1>Welcome back!</h1> : <h1>Please sign in.</h1>;
}

10.リストとキー

React では、map() メソッドを使用してデータのリストをレンダリングできます。各リスト項目には一意のキーが必要です。

例:

function ItemList(props) {
  const items = props.items;
  return (
    <ul>
      {items.map(item => <li key={item.id}>{item.name}</li>)}
    </ul>
  );
}

const items = [
  { id: 1, name: 'Apple' },
  { id: 2, name: 'Banana' },
  { id: 3, name: 'Cherry' }
];

<ItemList items={items} />;

11.ステータスアップ

場合によっては、複数のコンポーネントが同じ状態を共有する必要があります。状態を最も近い共通の祖先まで「引き上げる」ことで、それを小道具として受け継がせることができます。

例:

function TemperatureInput({ temperature, onTemperatureChange }) {
  return (
    <input
      type="text"
      value={temperature}
      onChange={e => onTemperatureChange(e.target.value)}
    />
  );
}

function Calculator() {
  const [temperature, setTemperature] = useState('');

  return (
    <div>
      <TemperatureInput
        temperature={temperature}
        onTemperatureChange={setTemperature}
      />
      <p>The temperature is {temperature}°C.</p>
    </div>
  );
}

これらは、React 開発の基礎を形成する基本概念です。

以上が反応の基本の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。