最近のアプリケーションに反応し、マップは常にシンプルになる前に、インラインスタイルを直接使用書きました。無料の利点を生かし、要約は、インラインスタイルを除いて、より良いスタイルのアプローチを反応させます。
1.classnameライブラリ
アセンブリは、動的なクラス名を容易にするために提供されます。
impoertは、{CompoNetを}を反応させから、 '反応します'。 |
CSSモジュール
ローカルスコープとスタイルモジュールの依存関係を達成するためのコンポーネント。
使用法:
CSS-ローダー構築されたCSSモジュールの機能をWebPACKのため、CSSモジュールを使用して、次のようにまず、WebPACKの設定でCSSモジュールを有効にする必要があります
?CSSモジュール&localIdentName = [名前] __ [ローカル] - [ハッシュ:BASE64:5 ] |
これはプラスモジュールは、localIdentNameが命名スタイルが設定されて有効になっています。
そして、組立CSSスタイルファイルのインポートには使用することを来ります。
.normal { |
その他の注意事項
グローバルスタイル:ローカルスタイルにCSSモジュールのデフォルトは、局所でのスタイル:ローカル小包は、生成されたCSS名はローカライズされたスタイルを実現するために、ランダムな数字の文字列を添付しました。
あなたは使用することができます:グローバルグローバルスタイルを実現します。:グローバル(.btn) {
...
}
gloablにおける//複数syle
:グローバル {
.normal {
...
}
.danger {
...
}
}- スタイルの再利用:コンを使用
{.base |
このとき、通常のスタイル要素またはコンポーネントを使用すると、実際には二つのクラスを生成します。
CSSモジュールはクラスセレクタを変更しますスタイルに関連付けられたクラス名を、変換します。だから、IDセレクタまたはセレクタ他の属性は、スタイルのCSSモジュールを変換されていません。
クラス名でのCSS Mdoules組み合わせたアプリケーションがに反応します:
...
インポートクラス名から 「クラス名」 ;
インポートスタイルから 」./styles.css' ;
クラス ダイアログ 延び コンポーネント {
(){レンダリング CONST({Cxが=クラス名 !:確認これは、.state.disabled disabledConfirmを:これは、.state.disabled })。リターン( <DIVクラス名= {styles.root}> <a className={styles[cx]}>確認< / A> </ div> ) }}
反応-CSS-モジュールライブラリをバインドするstyles.xxを入力しません。
//....
import CSSModules from 'react-css-modules';
//...
return (
<div styleName={root}>
<a styleName={cx}>Confirm</a>
</div>
)
export default CSSModules(Dialog, styles);
其它:
ts中import css文件的时候报错。
解决方法:增加一个module definition告诉typescript可以import css文件。
|
原文:大专栏 React中的样式处理