Reactにおけるオブジェクトからのstyle属性へのデータ挿入
CSSスタイルは、
属性styleを使用して要素に追加することもできます。
このレッスンと次のいくつかのレッスンでは、
インラインスタイリングの方法を検討します。
今回は、ファイルstyles.cssを接続せず、
対応する値を各タグのスタイルのオブジェクトとして
属性styleに渡します。
これらはコンポーネントファイルに直接記述します。
それでは、前のレッスンで作成した、 CSSスタイルのないコンポーネントを取り上げます:
function App() {
return (
<div>
<p>text</p>
<p>text</p>
<p>text</p>
</div>
);
}
ファイルApp.js内の
returnコマンドの前に、
変数class1にdivのCSSスタイルを持つオブジェクトを作成しましょう。
ここでのプロパティ名は
キャメルケース
表記で記述され、
プロパティ値は引用符で囲む必要があることを覚えておいてください:
const class1 = {
width: '200px',
border: '2px solid brown',
padding: '10px',
textAlign: 'center'
};
次に、最初の段落のスタイルを持つオブジェクトclass2を追加します:
const class2 = {
color: 'orangered',
fontWeight: 'bold'
}
2番目の段落のスタイルを持つオブジェクトclass3:
const class3 = {
fontStyle: 'italic',
color: 'brown',
}
そして最後に、最後の段落のためのclass4:
const class4 = {
backgroundColor: 'orange',
fontWeight: 'bold',
color: 'white',
}
次に、コンポーネントでCSSスタイルを適用するために、
属性styleを使用します。
最初の段落には変数class2がありました。
これを値として渡します:
<p style={class2}>text</p>
同様に、残りのタグにもオブジェクトからのスタイルを追加します。
結果として、コンポーネントのコードは次のようになります:
function App() {
const class1 = {
width: '200px',
border: '2px solid brown',
padding: '10px',
textAlign: 'center',
};
const class2 = {
color: 'orangered',
fontWeight: 'bold',
};
const class3 = {
fontStyle: 'italic',
color: 'brown',
};
const class4 = {
backgroundColor: 'orange',
fontWeight: 'bold',
color: 'white',
};
return (
<div style={class1}>
<p style={class2}>text</p>
<p style={class3}>text</p>
<p style={class4}>text</p>
</div>
);
}
前のレッスンの課題で作成したReactコンポーネントを使用して、
タグ用のCSSスタイルを持つオブジェクトを作成し、
対応するstyle属性に適用してください。