1. インラインスタイル利点: この方法は比較的シンプルで明確であり、タグにスタイル属性を追加します。 デメリット: この方法では、プロジェクト構造が肥大化し、CSS の名前付けの競合が発生する可能性があります。 React をインポートします。{ コンポーネント } を 'react' からインポートします。 'prop-types' から PropTypes をインポートします エクスポートデフォルトクラスインデックスはComponentを拡張します{ 静的プロパティタイプ = { タイトル: PropTypes.文字列 } 与える() { const h1Style={textAlign:'center',marginBottom:'20px',lineHeight:'35px', 高さ:'30px'} const {title} = this.props 戻る ( <div> <h1 style={h1Style}>{タイトル}</h1> <hr/> </div> ) } } 2. インポート方法を使用する利点: この方法は、CSSの外部導入と同様に、より柔軟に使用できます。 デメリット: Reactスタイルはデフォルトでグローバルなので、スタイルの競合が発生する可能性がある 使用方法: 新しい CSS ファイルを作成し、jsx 構文の className 属性を使用してクラス名を設定し、CSS でクラス名を使用します。このメソッドでは、変数を定義して三項式を使用してクラス名を選択できます。 React をインポートします。{ コンポーネント } を 'react' からインポートします。 「./index.css」をインポートします エクスポートデフォルトクラスインデックスはComponentを拡張します{ 状態={ フラグ:true } 色の変更=()=>{ this.setState((状態、プロパティ)=>{ 戻る { フラグ:!state.flag } }) } 与える() { const {flag} = this.state 戻る ( <div> <h1 className={flag?'blueColor':'redColor'}>髪が白くなるまで待たないでください</h1> <button onClick={this.changeColor} className="btnStyle">クリックしてフォントの色を変更します</button> </div> ) } } .blueColor{ 色: 青; } .redColor{ 色: 赤; } .btnスタイル{ 幅: 260ピクセル; 高さ: 50px; 背景色: 水色; 色: #fff; 境界線:なし; フォントサイズ: 28px; 境界線の半径: 10px; } 3.cssモジュールのエクスポート利点: 名前の競合がなく、スタイルはローカルでのみ有効です デメリット: 面倒すぎる。モジュールは毎回インポートおよびエクスポートする必要があり、これはすべての CSS クラス名をオブジェクトの属性として扱うのと同じです。オブジェクト属性が必要な場合は、オブジェクト属性を呼び出してクラス名を呼び出します。CSS の競合を解決する方法は、Vue でスタイルにモジュールを設定するのと同様に、異なるクラス名にプレフィックスを追加することです。 使用:
「react」からReact、{FC、useState}をインポートします。 「@/components1/cmittem」からCmittemをインポートします。 「./cmtlist.module.scss」から cssObj をインポートします。 定数コマンドリスト:FC<{}>=(props)=>{ 戻る ( <div> <h1 className={cssObj.title}>コメントリスト</h1> </div> ) } デフォルトの Cmtlist をエクスポートする 4. スタイル付きコンポーネントを使用する利点: テンプレート文字列タグ + スタイルの組み合わせは、大文字で始まるコンポーネントです。たとえば、React 開発で最も人気のある記述方法のいくつかを統合していると言えます。React 開発者にとって、これは非常に良いスタートです。そのため、React コンポーネントでは、開発者によって外部 CSS またはコンポーネント CSS を使用する習慣が異なります。 使用: styled-componentsをインストールする必要がある npm i styled-components または yarn add styled-components 簡単に書けるvscodeインストールプラグイン 4.1 初回使用'antd/dist/antd.less' をインポートします 'styled-components' から styled をインポートします 関数App() { const HomeWrapper = styled.div` フォントサイズ:50px; 色:赤; スパン{ 色:オレンジ; &。アクティブ{ 色:緑; } &:ホバー{ 色:青; フォントサイズ:40px; } &::後{ 内容:'ssss' } } ` 戻る ( <div className="アプリ"> <h1>私はタイトルです</h1> <ホームラッパー> <h2>私はサブタイトルです</h2> <span>カルーセル 1</span> <span className="active">カルーセル 2</span> <span>カルーセル 3</span> <span>カルーセル 4</span> </ホームラッパー> </div> ); } デフォルトのアプリをエクスポートします。 4.2 attrs による属性の設定'antd/dist/antd.less' をインポートします 'styled-components' から styled をインポートします 関数App() { const ChangeInput = styled.input.attrs({ プレースホルダー:'wangsu', bgColor:'赤' })` 背景色:#7a7ab4; 色:${props=>props.bgColor} ` 戻る ( <div className="アプリ"> <h1>私はタイトルです</h1> <ChangeInput タイプ="テキスト"/> </div> ); } デフォルトのアプリをエクスポートします。 4.3 CSS継承React をインポートします。{ コンポーネント } を 'react' からインポートします。 'styled-components' から styled をインポートします const HYbutton = styled.button` 色:赤; 境界線:1px実線 #ccc; パディング:10px 20px; ` //ここでは継承を使用します const XLbutton = styled(HYbutton)` 背景色:青; ` デフォルトクラス Button をエクスポートし、Component を拡張します { 与える() { 戻る ( <div> <HYbutton>これはボタンです</HYbutton> <XLbutton>これは継承されたボタンです</XLbutton> </div> ) } } 最近、プロジェクトを開発するときにこの方法を使用しています。とても斬新な感じがします。コミュニティでは議論がありますが、個人的にはこの CSS 設定方法が気に入っています。グローバル スタイルの問題をまったく考慮する必要がありません。 以上がReactでCSSをエレガントに書く方法の詳細です。ReactでCSSを書く方法の詳細については、123WORDPRESS.COMの他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
<<: Windows Server 2012 または 2016 でディスクなしで .NET Framework 3.5 をインストールできない問題に対する完璧なソリューション
>>: MySQL の一般的な SQL ステートメントの概要
フローティング要素は、親要素の高さを縮小します。要素を float float:left/right...
多くの友人がフォーラムやメッセージエリアで、どのような状況で MySQL をシャーディングする必要が...
目次1分でgithub+Jekyllブログにトラフィック機能を追加する1. ジェクルとは何か1. J...
目次序文実装のアイデア実装コード成果を達成する序文これは、テーブルを動的に追加する例です。[追加] ...
目次1. クエリの最適化1. MySQLチューニングの概要2. 小さなテーブルが大きなテーブルを動か...
目次序文1. リクエストをキャンセルする方法2. 重複リクエストの判定方法3. 繰り返しリクエストを...
目次1. はじめに2. JDBCはストリーミングクエリを実装する3. パフォーマンステスト3.1. ...
コードをコピーコードは次のとおりです。 <div contenteditable="...
mysql が誤ってデータを削除しました削除ステートメントを使用して誤ってデータ行を削除する誤ってデ...
序文最近、小さなプログラムを開発しているときに、このような問題に遭遇しました。ユーザーが認証をクリッ...
選択して変更: クリックすると現在の値が表示され、ページ UI が表示され、CSS スタイルが変更さ...
ラジオ ボタンや複数選択ボタンにスタイルを追加する方法や、ボタンを大きくする方法を尋ねる人を以前見か...
目次序文1. 新しいVueプロジェクトを作成する2. WebStormの設定1. デバッガポートを設...
序文Nginxの組み込みモジュールは、同時リクエスト数の制限とリクエストのソースの制限をサポートして...
目次序文始める序文サーバーのデフォルトの SSH ポート番号は通常 22 であるため、ほとんどのユー...