2017-03-01 13 views
1

webpackを使用して、グローバルなApp.lessファイルでantd.lessファイルをインポートしています。そして、私はいくつかのグローバルスタイルを上書きし、WebPACKのはeverthingバンドル:Antd:コンポーネントの1つのインスタンスのスタイルをオーバーライドする方法

{ 
     test: /\.less$/, 
     use: ExtractTextPlugin.extract({ 
      fallback: "style-loader", 
      use: [ 
      { 
       loader: "css-loader", 
       options: { importLoaders: 1} 
      }, 
      "less-loader" 
      ] 
     }) 
    }, 
    { 
     test: /\.css$/, 
     use: ExtractTextPlugin.extract({ 
      fallback: "style-loader", 
      use: "css-loader" 
     }) 
    } 

今、例えば、私はタブの1つのインスタンスのサイズを上書きしたい:私のWebPACK 2設定がそのように見える

// App.less 
@import "~antd/dist/antd.less"; 
@import "./fonts.css"; 
@import "./reactSplitPane.css";  

@heading-color   : fade(#000, 100%); 
@text-color    : fade(#000, 100%); 
@text-color-secondary : fade(#000, 100%); 
@disabled-color   : fade(#000, 25%); 

成分。それを行う最良の方法は何ですか?

タブ・バーの下のラインの色を上書きする例:

.ipf-appbar { 
    font-size: 24px; // this applies to all text in the Tabs component 
    border-bottom: 1px solid darkmagenta; // also applies to all border 
} 
.ant-tabs-bar { 
    border-bottom: 1px solid darkmagenta; // this applies only to the desired div but is global 
} 

しかし、これは、ただ1つのコンポーネントに対して有効にする必要があります。コンポーネントは、この(活字体)のようになります。あなたはカスタムCSSクラス/ IDを追加することにより、CSSでTabsコンポーネントをターゲットとすべき

import * as ReactDOM from "react-dom"; 
import * as React from "react"; 
import { Tabs } from "antd"; 
import "./AppBar.less"; 

export class AppBar extends React.Component<undefined, undefined> { 
    render() { 
     return (
      // <Tabs className="ipf-appbar"> 
      <Tabs> 
       <Tabs.TabPane tab="Start" key="1">Start</Tabs.TabPane> 
       <Tabs.TabPane tab="Projekte" key="2">Projekte</Tabs.TabPane> 
      </Tabs> 
     ); 
    } 
} 
+1

私はTSと反応し使用してい –

+0

ので、私は私の例では、より具体的にすることができ、あなたのHTMLコードを追加してください。私の更新を参照してください。 – Knack

答えて

3

。その後、あなたのCSSファイルでそのクラス/ IDをカスタマイズすることができます。次のように.ipf-appbarクラスを追加するには、特定のケースでは、その特定のコンポーネントのスタイルを設定することができます

.ipf-appbar .ant-tabs-bar { 
    font-size: 24px; // this applies to all text in the Tabs component 
    border-bottom: 1px solid darkmagenta; // also applies to all border 
} 
+0

このコンポーネントの特定の「ネスト」クラスをどのように上書きしますか?例えば。 '.ant-tabs-bar {border-bottom:1px solid darkmagenta; } '。 1つのインスタンスにのみ適用する必要があります。 – Knack

+0

スペースを追加する必要がありました... .ipf-appbar .ant-tabs-bar'。完璧に動作します。乾杯! – Knack

関連する問題