[解決済み] Reactのこの3つの点は何をするところなのでしょうか?
2022-03-17 20:46:57
質問
とは何ですか?
...
このReact(JSXを使用)のコードで行うことと、その名前は何でしょうか?
<Modal {...this.props} title='Modal heading' animation={false}>
解決方法は?
それは プロパティスプレッド表記 . ES2018で追加されましたが(配列/イテラブルに対するspreadはそれ以前のES2015)、Reactのプロジェクトでは以前からトランスパイルでサポートされています(".として)。 JSX拡散属性 "属性だけでなく、他の場所でもできるのにね)。
{...this.props}
広がる
の列挙可能なプロパティです。
props
を離散的なプロパティとして
Modal
要素を作成します。例えば
this.props
を含む
a: 1
と
b: 2
であれば
<Modal {...this.props} title='Modal heading' animation={false}>
と同じになります。
<Modal a={this.props.a} b={this.props.b} title='Modal heading' animation={false}>
しかし、これは動的なものなので、どのようなquot;own"プロパティが
props
が含まれます。
以来
children
のプロパティです。
props
の場合、spread はそれを含む。つまり、これが表示されるコンポーネントに子要素があった場合、その子要素は
Modal
. 開始タグと終了タグの間に子要素を置くことは、単なる構文上の糖分(良い意味での糖分)であり、そのために
children
プロパティがあります。例
class Example extends React.Component {
render() {
const { className, children } = this.props;
return (
<div className={className}>
{children}
</div>
);
}
}
ReactDOM.render(
[
<Example className="first">
<span>Child in first</span>
</Example>,
<Example className="second" children={<span>Child in second</span>} />
],
document.getElementById("root")
);
.first {
color: green;
}
.second {
color: blue;
}
<div id="root"></div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>
Spread記法は、このような用途だけでなく、既存のオブジェクトのプロパティのほとんど(またはすべて)を持つ新しいオブジェクトを作成する場合にも便利です。
this.setState(prevState => {
return {foo: {...prevState.foo, a: "updated"}};
});
を置き換えます。
this.state.foo
と同じプロパティを持つ新しいオブジェクトに変更します。
foo
ただし
a
プロパティになり
"updated"
:
const obj = {
foo: {
a: 1,
b: 2,
c: 3
}
};
console.log("original", obj.foo);
// Creates a NEW object and assigns it to `obj.foo`
obj.foo = {...obj.foo, a: "updated"};
console.log("updated", obj.foo);
.as-console-wrapper {
max-height: 100% !important;
}
関連
-
fetch ネットワークリクエストラッパーの説明例
-
vueディレクティブv-bindの使用と注意点
-
[解決済み】リソースの読み込みに失敗した:Bind関数でサーバーが500(Internal Server Error)のステータスで応答した【非公開
-
[解決済み] JavaScriptで "use strict "は何をするのか、その根拠は?
-
[解決済み] なぜGoogleはJSONレスポンスにwhile(1);を前置するのでしょうか?
-
[解決済み] とは何ですか! (not not)演算子とは何ですか?
-
[解決済み] callとapplyの違いは何ですか?
-
[解決済み] Reactルータを使ったプログラムによるナビゲーション
-
[解決済み] React JSX内のループ
-
[解決済み】jQueryでチェックボックスがチェックされているかどうかを確認するにはどうすればよいですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
fetch ネットワークリクエストラッパーの説明例
-
Vueにシンプルなメモ帳機能を実装
-
Javascript Bootstrapのグリッドシステム、ナビゲーションバー、ローテーションの説明
-
[解決済み] Error : 未定義のプロパティ 'map' を読み取ることができません。
-
[解決済み】SyntaxError: JSONの位置1に予期しないトークンoがある。
-
[解決済み] Web API エラー - このリクエストはブロックされました; コンテンツは HTTPS で提供されなければなりません
-
[解決済み】ExpressJS : res.redirect()が期待通りに動かない?
-
[解決済み】React Uncaught Error: 対象コンテナが DOM 要素でない [重複]。
-
[解決済み】 Uncaught TypeError : undefined のプロパティ 'replace' を読み取れない In Grid
-
JavaScriptのgetElementById()メソッド入門