ホームページ > ウェブフロントエンド > htmlチュートリアル > CSS モジュールの使用量tutorial_html/css_WEB-ITnose

CSS モジュールの使用量tutorial_html/css_WEB-ITnose

WBOY
リリース: 2016-06-21 08:46:28
オリジナル
926 人が閲覧しました

Web 開発を学んだことがある方なら、CSS はプログラミング言語ではなく、Web ページのスタイルを記述する方法であることをご存知でしょう。

CSS をソフトウェア工学手法に適用できるようにするために、プログラマーは CSS をプログラミング言語のようにするためのさまざまな方法を考えてきました。初期の Less と SASS から、その後の PostCSS、そして最近の JS の CSS に至るまで、それらはすべてこの問題を解決するために設計されています。

この記事で紹介する CSS モジュールは異なります。 CSS をプログラミング言語に変換するわけではありませんが、その機能は非常に単純で、ローカル スコープとモジュールの依存関係を追加するだけです。これはまさに Web コンポーネントの最も緊急に必要な機能です。

したがって、CSS モジュールにはルールがほとんどないため、習得が簡単であり、同時に、特定のコンポーネントのスタイルが他のコンポーネントに影響を与えないようにすることができます。

ゼロ、サンプル ライブラリ

このチュートリアル用にサンプル ライブラリを作成しました。これには 6 つのデモが含まれています。これらを通じて、CSS モジュールを簡単に学ぶことができます。

まず、サンプル リポジトリのクローンを作成します。

$ git clone git@github.com:ruanyf/css-modules-demos.git
ログイン後にコピー

次に、依存関係をインストールします。

$ cd css-modules-demos$ npm install
ログイン後にコピー

これで、最初の例を実行できます。

$ npm run demo01
ログイン後にコピー
ログイン後にコピー

ブラウザを開いて http://localhost:8080 にアクセスして結果を表示します。他の例も同様に実行されます。

1. ローカル スコープ

CSS ルールはグローバルであり、どのコンポーネントのスタイル ルールもページ全体に有効です。

ローカル スコープを作成する唯一の方法は、他のセレクターと同じ名前を持たない一意のクラス名を使用することです。これが CSS モジュールの機能です。

以下は React コンポーネント App.js です。

import React from 'react';import style from './App.css';export default () => {  return (    <h1 className={style.title}>      Hello World    </h1>  );};
ログイン後にコピー
ログイン後にコピー

上記のコードでは、スタイル ファイル App.css をスタイル オブジェクトに入力し、style.title を参照してクラスを表しています。

.title {  color: red;}
ログイン後にコピー

ビルド ツールは、クラス名 style.title をハッシュ化された文字列にコンパイルします。

<h1 class="_3zyde4l1yATCOkgn-DBWEL">  Hello World</h1>
ログイン後にコピー

App.css も同時にコンパイルされます。

._3zyde4l1yATCOkgn-DBWEL {  color: red;}
ログイン後にコピー

このようにして、クラス名は一意になり、App コンポーネントに対してのみ有効になります。

CSS モジュールは、さまざまなビルド ツールをサポートするさまざまなプラグインを提供します。この記事では、Webpack の css-loader プラグインを使用します。これは、CSS モジュールを最もよくサポートしており、使いやすいためです。ちなみに、Webpack を学びたい場合は、私のチュートリアル Webpack-Demos を読んでください。

この例の webpack.config.js は次のとおりです。

module.exports = {  entry: __dirname + '/index.js',  output: {    publicPath: '/',    filename: './bundle.js'  },  module: {    loaders: [      {        test: /\.jsx?$/,        exclude: /node_modules/,        loader: 'babel',        query: {          presets: ['es2015', 'stage-0', 'react']        }      },      {        test: /\.css$/,        loader: "style-loader!css-loader?modules"      },    ]  }};
ログイン後にコピー

上記のコードのキー行は style-loader!css-loader?modules で、css-loader の後にクエリ パラメータ module を追加し、CSS モジュールを開くことを示します。関数。

次に、デモを実行します。

$ npm run demo01
ログイン後にコピー
ログイン後にコピー

http://localhost:8080 を開くと結果が表示され、h1 タイトルが赤色で表示されます。

2. グローバル スコープ

CSS モジュールでは、:global(.className) 構文を使用してグローバル ルールを宣言できます。この方法で宣言されたクラスは、ハッシュ文字列にコンパイルされません。

App.css にグローバル クラスを追加します。

.title {  color: red;}:global(.title) {  color: green;}
ログイン後にコピー

App.jsは通常のクラス記述方法を使用しており、グローバルクラスを参照します。

import React from 'react';import styles from './App.css';export default () => {  return (    <h1 className="title">      Hello World    </h1>  );};
ログイン後にコピー

この例を実行します。

$ npm run demo02
ログイン後にコピー

http://localhost:8080 を開くと、h1 ヘッダーが緑色で表示されるはずです。

CSS モジュールは、明示的なローカル スコープ構文 local(.className) も提供します。これは .className と同等であるため、上記の App.css は次のように記述することもできます。

:local(.title) {  color: red;}:global(.title) {  color: green;}
ログイン後にコピー

3. カスタマイズされたハッシュ クラス名

css-loader のデフォルトのハッシュ アルゴリズムは [hash:base64] で、.title を文字列にコンパイルします。 ._3zyde4l1yATCOkgn-DBWEL のように。

ハッシュ文字列の形式は webpack.config.js でカスタマイズできます。

module: {  loaders: [    // ...    {      test: /\.css$/,      loader: "style-loader!css-loader?modules&localIdentName=[path][name]---[local]---[hash:base64:5]"    },  ]}
ログイン後にコピー

この例を実行します。

$ npm run demo03
ログイン後にコピー

.title が、demo03-components-App---title---GpMto にコンパイルされていることがわかります。

4. クラスの組み合わせ

CSS モジュールでは、セレクターは別のセレクターのルールを継承できます。これを「合成」と呼びます。

App.css で、 .title に .className を継承させます。

.className {  background-color: blue;}.title {  composes: className;  color: red;}
ログイン後にコピー

App.js を変更する必要はありません。

import React from 'react';import style from './App.css';export default () => {  return (    <h1 className={style.title}>      Hello World    </h1>  );};
ログイン後にコピー
ログイン後にコピー

この例を実行します。

$ npm run demo04
ログイン後にコピー

http://localhost:8080 を開くと、青い背景に赤い h1 が表示されます。

App.css は以下のコードにコンパイルされます。

._2DHwuiHWMnKTOYG45T0x34 {  color: red;}._10B-buq6_BEOTOl9urIjf8 {  background-color: blue;}
ログイン後にコピー

同様に、 h1 クラスも

にコンパイルされます。

5. 他のモジュールを入力します

セレクターは他の CSS ファイルのルールを継承することもできます。

another.css

.className {  background-color: blue;}
ログイン後にコピー

App.css は、another.css のルールを継承できます。

.title {  composes: className from './another.css';  color: red;}
ログイン後にコピー

运行这个示例。

$ npm run demo05
ログイン後にコピー

打开 http://localhost:8080 ,会 看到 蓝色的背景上有一个红色的 h1 。

六、输入变量

CSS Modules 支持使用变量,不过需要安装 PostCSS 和 postcss-modules-values 。

$ npm install --save postcss-loader postcss-modules-values
ログイン後にコピー

把 postcss-loader 加入 webpack.config.js 。

var values = require('postcss-modules-values');module.exports = {  entry: __dirname + '/index.js',  output: {    publicPath: '/',    filename: './bundle.js'  },  module: {    loaders: [      {        test: /\.jsx?$/,        exclude: /node_modules/,        loader: 'babel',        query: {          presets: ['es2015', 'stage-0', 'react']        }      },      {        test: /\.css$/,        loader: "style-loader!css-loader?modules!postcss-loader"      },    ]  },  postcss: [    values  ]};
ログイン後にコピー

接着,在 colors.css 里面定义变量。

@value blue: #0c77f8;@value red: #ff0000;@value green: #aaf200;
ログイン後にコピー

App.css 可以引用这些变量。

@value colors: "./colors.css";@value blue, red, green from colors;.title {  color: red;  background-color: blue;}
ログイン後にコピー

运行这个示例。

$ npm run demo06
ログイン後にコピー

打开 http://localhost:8080 ,会 看到 蓝色的背景上有一个红色的 h1 。

(完)

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート