ホームページ >ウェブフロントエンド >CSSチュートリアル >VueはCSS変数を使用してテーマ切り替え機能を実装します
テーマ管理は Web サイトでよく見られますが、一般的な考え方は、テーマに関連する CSS スタイルを分離し、ユーザーがテーマを選択したときに対応する CSS スタイル ファイルを読み込むことです。ほとんどのブラウザは CSS 変数と互換性があり、テーマ スタイルの管理が容易になりました。最近、CSS 変数を使用して Vue プロジェクトでテーマを設定する練習をしました。プロセス全体を見てみましょう。
Github プロジェクト アドレス https://github.com/JofunLiang/vue-project-themable-demo
デモ アドレス https://jofunliang.github .io/vue-project-themable-demo/
実現可能性テスト
メソッドの実現可能性をテストするには、パブリック フォルダーの下に新しいテーマ フォルダーを作成します。そして、themes フォルダーに新しい default.css ファイルを作成します:
:root { --color: red; }
推奨学習: CSS ビデオ チュートリアル
in 次のように、外部スタイル theme.css をパブリック フォルダーの Index.html ファイルに導入します:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width,initial-scale=1.0"> <link rel="icon" href="<%= BASE_URL %>favicon.ico"> <title>vue-skin-peeler-demo</title> <!-- 引入themes文件夹下的default.css --> <link rel="stylesheet" type="text/css" href="src/themes/default.css" rel="external nofollow"> </head> <body> <noscript> <strong>We're sorry but vue-skin-peeler-demo doesn't work properly without JavaScript enabled. Please enable it to continue.</strong> </noscript> <div id="app"></div> <!-- built files will be auto injected --> </body> </html>
次に、Home.vue で CSS 変数を使用します:
<template> <div> <div :class="$style.demo">变红色</div> </div> </template> <script> export default { name: 'home' } </script> <style module> .demo { color: var(--color); } </style>
次に、プロジェクトを実行してブラウザでページを開くと、ページは通常どおり表示されます。
注: CSS スタイルを導入するために link タグを使用する @vue/cli は、「申し訳ありませんが、JavaScript が有効になっていないと vue-skin-peeler-demo は適切に動作しません。お願いします」というエラーを報告する場合があります。続行できるようにします。」これは、@vue/cli が webpack を介して src ディレクトリ内のすべてのファイルをパッケージ化することが原因で発生するため、静的ファイル リソースは public (@vue/cli 2.x バージョンが静的ディレクトリに配置されている場合) フォルダーに配置する必要があります。
テーマ切り替えの実装
ここでのテーマ切り替えのアイデアは、リンク タグの href 属性を置き換えることです。 src に置換関数を記述する必要があります。ディレクトリに新しい themes.js ファイルを作成します。コードは次のとおりです。
// themes.js const createLink = (() => { let $link = null return () => { if ($link) { return $link } $link = document.createElement('link') $link.rel = 'stylesheet' $link.type = 'text/css' document.querySelector('head').appendChild($link) return $link } })() /** * 主题切换函数 * @param {string} theme - 主题名称, 默认default * @return {string} 主题名称 */ const toggleTheme = (theme = 'default') => { const $link = createLink() $link.href = `./themes/${theme}.css` return theme } export default toggleTheme
次に、default.css## を作成します。テーマ ファイルの下の # と dark.css 2 つのテーマ ファイル。テーマを実装するための CSS 変数を作成します。 CSS 変数を使用したテーマの切り替えを実装するには、別の記事を参照してください。CSS 変数を使用する最初の問い合わせ
互換性
IE ブラウザと一部の古いブラウザは CSS 変数をサポートしていません。したがって、古いブラウザと最新のブラウザの両方で CSS カスタム プロパティ (「CSS 変数」とも呼ばれます) のクライアント側サポートを提供する ponyfill である css-vars-ponyfill が必要です。監視監視を有効にする必要があるため、MutationObserver.js もインストールする必要があります。インストール:
npm install css-vars-ponyfill mutationobserver-shim --save次に、これを Themes.js ファイルに導入して使用します:
// themes.js import 'mutationobserver-shim' import cssVars from 'css-vars-ponyfill' cssVars({ watch: true }) const createLink = (() => { let $link = null return () => { if ($link) { return $link } $link = document.createElement('link') $link.rel = 'stylesheet' $link.type = 'text/css' document.querySelector('head').appendChild($link) return $link } })() /** * 主题切换函数 * @param {string} theme - 主题名称, 默认default * @return {string} 主题名称 */ const toggleTheme = (theme = 'default') => { const $link = createLink() $link.href = `./themes/${theme}.css` return theme } export default toggleTheme監視をオンにした後、IE 11 をクリックします。ブラウザのテーマの切り替えが機能しません。そのため、テーマを切り替えるたびに cssVars() を再実行しても、テーマを切り替えることはできず、ウォッチを ON にした後の cssVars() の再実行は無効となるためです。最後に、唯一のオプションは、時計の電源をオフにしてから再度オンにすることです。テーマを正常に切り替えるための Strategies.js コードは次のとおりです:
// themes.js import 'mutationobserver-shim' import cssVars from 'css-vars-ponyfill' const createLink = (() => { let $link = null return () => { if ($link) { return $link } $link = document.createElement('link') $link.rel = 'stylesheet' $link.type = 'text/css' document.querySelector('head').appendChild($link) return $link } })() /** * 主题切换函数 * @param {string} theme - 主题名称, 默认default * @return {string} 主题名称 */ const toggleTheme = (theme = 'default') => { const $link = createLink() $link.href = `./themes/${theme}.css` cssVars({ watch: false }) setTimeout(function () { cssVars({ watch: true }) }, 0) return theme } export default toggleThemeすべてのコードを表示するには、Github プロジェクト アドレスにアクセスしてください。
テーマを記憶する
テーマを記憶する機能を実装するには、1 つはテーマをサーバーに保存する方法、もう 1 つはローカル ストレージ テーマを使用する方法です。 。便宜上、ここではテーマのローカル ストレージ メソッドが主に使用されます。つまり、テーマの保存には localStorage が使用されます。具体的な実装については、Github プロジェクトのアドレスをご覧ください。 この記事は、PHP 中国語 Web サイトのCSS チュートリアル 列から引用したものです。学習へようこそ
以上がVueはCSS変数を使用してテーマ切り替え機能を実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。