Vue で CSS カスタム変数を使用する方法

Vue で CSS カスタム変数を使用する方法

CSS カスタム変数機能は古くから存在していますが、実際の開発ではあまり使用されていません。その理由は、lessやsassなどのプリプロセッサにはすでに変数を定義する機能があり、Vueやreactはスタイルを設定するのに非常に便利だからです。cssを使用して変数を定義するのは不便で不必要だと思う人もいるかもしれません。実際はそうではありません。最も直感的な例、「Vue を使用して疑似クラスの疑似要素のスタイルを設定する方法」を見てみましょう。これは 1 世紀も前からある問題です。ほとんどの人はクラス名を変更することで解決できるかもしれませんが、変更するスタイルが多数ある場合や、異なるデータで異なるスタイルをレンダリングしたい場合はどうすればよいでしょうか。今日はこの問題について直接お話ししたいと思います。 まず、CSS カスタム変数とは何かを理解しましょう。 使い方は簡単:

<スタイル>
div {
    --bg-color : pink; //変数を定義 color : var( --bg-color ) //var関数を通じて変数を使用する}
</スタイル>
<div>こんにちは</div>

ピンクの「こんにちは」が届きます。親で定義された変数は、子要素とその疑似クラスでも使用できます。

<スタイル>
div {
    --bg-color : pink; //変数を定義する color : var( --bg-color ); //var関数を通じて変数を使用する}
div:ホバー{
    背景色: var( --bg-color );
}
div スパン {
    背景色: var( --bg-color );
}
</スタイル>
<div>こんにちは <span>世界</span> </div>

var 関数はデフォルト値を設定することもできます。カスタム変数が見つからない場合にもデフォルト値を設定できます。

<スタイル>
div {
    color : var( --bg-color, pink ); // 2 番目のパラメータはデフォルト値です background-color : var( --bg-color ,--color,--a,red ); // 複数の変数を設定することもできます。左から右に検索されます }
</スタイル>
<div>こんにちは</div>

これで CSS カスタム変数の紹介は終了です。次に、Vue での使用法を見てみましょう。タグのスタイル属性で変数の値を設定できます。

<テンプレート>
	<div class="box" @click="changeColor" :style="{'--a' : a}">こんにちは</div>
</テンプレート>
エクスポートデフォルト{
  データ(){
    戻る {
      a : 「青」、
    }
  },
  メソッド: {
    色を変更する(){
      this.a = this.a === 'blue' ? "red" : "blue"
    }
  }
}
</スクリプト>
<スタイル>
  。箱 {
      色: var(--a);
  }
  .box:hover {
    背景色: var(--a);
  }
</スタイル>

div をクリックすると、マウスを置いたときのフォントの色と背景色が変わります。この時点で、CSS 変数をカスタマイズすることで、スタイルを簡単に変更し、疑似クラスのプロパティを直接変更できることがわかります。子要素は親のカスタム変数を共有できるため、親独自の変数を子コンポーネントで直接使用できます。

// 親コンポーネント <テンプレート>
	<div class="box" :style="{'--a' : a}">こんにちは <Child></Child></div>
</テンプレート>
エクスポートデフォルト{
  コンポーネント: {
      子供
  },
  データ(){
    戻る {
      a : 「青」、
    }
  }
}
</スクリプト>

//子コンポーネント
<テンプレート>
  <span>世界</span>
</テンプレート>

<スタイル lang="less">
  スパン {
      色: var(--color);
  }
</スタイル>

試してみると、その効果は驚くべきものです。このようにして、子コンポーネントと親コンポーネント間の値の転送をバイパスして、親コンポーネントの状態を変更して子コンポーネントのスタイルを変更することができます。注意: サブコンポーネントは、変数を使用できるスコープ クラスにマウントする必要があります。

上記の例から、サブ定義変数の便利さがわかります。使いやすさのために、vue カスタム命令を通じて変数を設定できます。

   // vue3 カスタムディレクティブ。
      関数 change(el,binding){
        for(let [key,value] of Object.entries(binding.value)){
            el.style.setProperty('--'+キー、値);
        }
    }
  app.directive(css, {
        マウント(el,binding){
            変更(el,バインディング)
        }
        更新(el, バインディング) {
            変更(el,バインディング)
        }
       
    })

el.style['--color'] = 'red' を使用して CSS 変数を変更することは無効であり、style.setProperty API を使用して設定する必要があることに注意してください。指示を登録したら可能です。

<テンプレート>
	<div v-css="{a,b}" クラス="box" @click="changeColor"></div>
</テンプレート>
エクスポートデフォルト{
  データ(){
    戻る {
      a : 「青」、
      b : 「ピンク」
    }
  },
  メソッド: {
    色を変更する(){
      this.a = this.a === 'blue' ? "red" : "blue"
      this.b = this.b === 'ピンク' ? "黄色" : "ピンク"
    }
  }
}
</スクリプト>
<スタイル>
  。箱 {
    幅: 100px;
    高さ: 100px;
    背景色: var(--a);
  }
  .box:hover {
    背景色: var(--b);
  }
</スタイル>

これにより、Vue のスタイル操作が大幅に容易になります。

これを基に、いくつかの最適化と拡張を行い、ツールを公開し、npm で公開しました。アドレスは www.npmjs.com/package/vue… です。ぜひダウンロードして体験してください。気に入ったら、スターを付けてください。

上記は、Vue が CSS カスタム変数を使用する方法の詳細です。Vue が CSS カスタム変数を使用する方法の詳細については、123WORDPRESS.COM の他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • 定義済み変数を使用して Vue で CSS スタイルを設定する方法の詳細な説明

<<:  Linuxパフォーマンス監視コマンドの簡単な紹介

>>:  MySQL 8 の新機能: 非表示のインデックス

推薦する

検索ボックスと検索ボタンの境界線が重なり合わない問題を解決

今日、Baiduのページで練習していたところ、検索ボックスとボタンの余白とパディングの値が0に設定さ...

HTML マークアップ言語 - テーブルタグ

123WORDPRESS.COM HTML チュートリアル セクションに戻るには、ここをクリックして...

ECMAScript の演算子を理解するための記事

目次単項演算子ブール演算子乗算演算子加法演算子関係演算子等価演算子条件演算子代入演算子カンマ演算子要...

Tomcat マルチポートドメイン名アクセスと gzip 圧縮方式を有効にする構成

1. デフォルトのポート8080に加えて、ドメイン名のアクセスとserver.xmlのオープンにポー...

10 HTML テーブル関連タグ

実際、多くの人が「テーブルは絶対に使用すべきではないと聞いたことがある」と言いますが、これは絶対に間...

MySQL でのトリガーとカーソルの紹介と使用

トリガーの紹介トリガーは、テーブルに関連付けられた特別なストアド プロシージャであり、テーブル内のデ...

Apache SkyWalking アラーム設定ガイドの詳細な説明

アパッチ スカイウォーキングApache SkyWalking は、マイクロサービス、クラウド ネイ...

実行中の Docker コンテナにボリュームを動的に追加する方法

以前、Docker コンテナの起動後にボリュームをマウントできるかどうか尋ねられたことがあります。m...

MySQL の大きなデータ テーブルにフィールドを追加する方法

序文フィールドの追加は誰でもよく知っていると思います。簡単に記述できます。MySQL テーブルにフィ...

DD DT DLタグの使用例

通常は <ul><li> タグを使用しますが、dd タグと dt タグも便利...

CSS3ダイヤモンドパズルはdivのみを回転し、背景画像は回転しない機能を実現します

需要背景プロジェクトはVueを使用して作成され、ビジネス要件にはパズル効果があります。デフォルトの背...

Javascript配列の重複排除のいくつかの方法の詳細な説明

目次アレイ重複排除1 2層forループ(バブルソートの2層ループ記述に類似) 2 ループとインデック...

Vue はトークンの有効期限が切れると自動的にログインページにジャンプする機能を実装します

このプロジェクトは最近テストされ、テスターから、トークンの有効期限が切れたため、ルートが自動的にログ...

MySQLクエリ最適化分析チュートリアルをステップバイステップで教えます

序文MySQL は、強力なクエリ機能、高いデータ一貫性、高いデータ セキュリティ、およびセカンダリ ...

ウェブページの表の分割線を削除する方法

<br />Web テーブルの分割線を削除する方法。実際、上記の 3 つの表はいずれも ...