以下に、vue +less を使用して簡単なスキン変更関数を実装する例を紹介します。これは非常に参考になるので、皆さんの参考になれば幸いです。
スキン変更エフェクトは比較的シンプルで、上部のナビゲーションの背景色を変更するだけです。 以下はレンダリングです。
まず、私の最初の考えを話させてください。
私の最初のアイデアは、変数の定義に使用する変数を減らし、js を通じて変数を切り替え、切り替えた変数を通じてスキンを変える効果を実現するというものでした。
私は最初に次のコードで新しいtheme.lessファイルを作成しました:
@theme:@themea; @themea:pink; @themeb:blue; @themec:gray;
私の当初のアイデアとして、変数@themeの値はクリックイベントを通じて変更されるべきです。
私は element-ui フレームワークを使用したので、ドロップダウン メニューのコードは複雑ではありません:
<el-dropdown class="colorBtn " trigger="click" @command="changeColor"> <span class="el-dropdown-link " >换肤</span> <el-dropdown-menu slot="dropdown"> <el-dropdown-item command="a" @click="change_type(a)">梦幻粉</el-dropdown-item> <el-dropdown-item command="b" @click="change_type(b)">天空蓝</el-dropdown-item> <el-dropdown-item command="c" @click="change_type(c)">雾霾灰</el-dropdown-item> </el-dropdown-menu> </el-dropdown>
click イベントのコールバック イベントは command イベントにバインドされており、changeColor メソッドを定義しました
changeColor(command){ console.log(command);//能获取到当前点击的元素的command }
それで、質問は、クリックイベントを通じて @theme の値を変更するにはどうすればよいですか?私は深い(検索)思考(思考)に陥りました...
最終的に問題を解決する遠回りな方法を見つけました。実際、元のアイデアは問題ありませんでしたが、もう少しパッケージ化する必要がありました。梱包方法は?変数の値は今のところ制御できませんが、要素のクラス名は制御できます。
スキニング部分を抽出し、less 関数を使用してそれを表し、theme.less コードを次のコードに変更します
ここで、@backcolor は背景色、@fcolor はフォントの色です
.theme(@backcolor:#EEA2AD,@fcolor:#fff) { .header { color: @fcolor; background: @backcolor; width: 100%; height: 2rem; position: relative; h4 { width: 100%; text-align: center; line-height: 2rem; font-size: 1rem; } .go-back { width: 2rem; height: 2rem; text-align: center; color: #fff; font-size: 0.8rem; float: left; line-height: 2rem; margin-left: 1rem; position: absolute; left: 0; top: 0; } .header-cont { width: 100%; text-align: center; line-height: 2rem; font-size: 1rem; color: #fff; } .colorBtn { width: 2rem; height: 2rem; text-align: center; color: #fff; font-size: 0.8rem; line-height: 2rem; margin-right: 1rem; position: absolute; top: 0; right: 0; } } }
Create新しい color.less では、いくつかの異なるスキン スタイルを設定します。ここでのさまざまなスキン スタイルは、コンポーネントのコマンド値に対応する、themea、themeb、themec... で表されます。ピンク色をクリックすると、対応する関数が呼び出され、対応するクラス名が要素に追加されます。 theme.less を引用することを忘れないでください
@import url('./theme.less'); .themea{ .theme();//默认的样式 } .themeb{ .theme(blue,#fff); } .themec{ .theme(#111,#999); }
スキンされたドロップダウン メニューをクリックすると、呼び出される changeColor メソッドで要素に別のクラス名を追加する必要があります。もちろん、color.less ファイルを引用することを忘れないでください。
changeColor(command){ console.log(command); document.getElementById('app').className ='theme'+command ; }
この作品に取り組んでいるとき、私も最初に問題に遭遇しました。つまり、最初にこのページのスタイルを個別に抽出しただけなので、他のコンポーネントのヘッドスタイルは変更されませんでした。最初に考えたのは、Cookie を使用することでした。それでは、単一のページなので、スタイルをトップレベルの要素にバインドしてもよいのではないかと考えました。
結果は明らかです! ! !
最後のスキン変更を覚えておきたい場合は、localStorage を使用して各スキン変更のテーマを記録し、ページをレンダリングする前にそのようなテーマがあるかどうかを判断します。効果は以下の通りです
以上、皆さんの参考になれば幸いです。
関連記事:
vue-cliパッケージ化時のプロジェクト関連の設定ファイル抽出問題について(詳細チュートリアル)
Vueを使用したルーティング権限管理の問題(詳細チュートリアル)
使い方についてvue.js タグ属性に変数パラメーターを挿入する (詳細なチュートリアル)
以上がvue+lessを使った簡単なスキン変更機能の実装方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

PythonとJavaScriptの主な違いは、タイプシステムとアプリケーションシナリオです。 1。Pythonは、科学的コンピューティングとデータ分析に適した動的タイプを使用します。 2。JavaScriptは弱いタイプを採用し、フロントエンドとフルスタックの開発で広く使用されています。この2つは、非同期プログラミングとパフォーマンスの最適化に独自の利点があり、選択する際にプロジェクトの要件に従って決定する必要があります。

PythonまたはJavaScriptを選択するかどうかは、プロジェクトの種類によって異なります。1)データサイエンスおよび自動化タスクのPythonを選択します。 2)フロントエンドとフルスタック開発のためにJavaScriptを選択します。 Pythonは、データ処理と自動化における強力なライブラリに好まれていますが、JavaScriptはWebインタラクションとフルスタック開発の利点に不可欠です。

PythonとJavaScriptにはそれぞれ独自の利点があり、選択はプロジェクトのニーズと個人的な好みに依存します。 1. Pythonは、データサイエンスやバックエンド開発に適した簡潔な構文を備えた学習が簡単ですが、実行速度が遅くなっています。 2。JavaScriptはフロントエンド開発のいたるところにあり、強力な非同期プログラミング機能を備えています。 node.jsはフルスタックの開発に適していますが、構文は複雑でエラーが発生しやすい場合があります。

javascriptisnotbuiltoncorc;それは、解釈されていることを解釈しました。

JavaScriptは、フロントエンドおよびバックエンド開発に使用できます。フロントエンドは、DOM操作を介してユーザーエクスペリエンスを強化し、バックエンドはnode.jsを介してサーバータスクを処理することを処理します。 1.フロントエンドの例:Webページテキストのコンテンツを変更します。 2。バックエンドの例:node.jsサーバーを作成します。

PythonまたはJavaScriptの選択は、キャリア開発、学習曲線、エコシステムに基づいている必要があります。1)キャリア開発:Pythonはデータサイエンスとバックエンド開発に適していますが、JavaScriptはフロントエンドおよびフルスタック開発に適しています。 2)学習曲線:Python構文は簡潔で初心者に適しています。 JavaScriptの構文は柔軟です。 3)エコシステム:Pythonには豊富な科学コンピューティングライブラリがあり、JavaScriptには強力なフロントエンドフレームワークがあります。

JavaScriptフレームワークのパワーは、開発を簡素化し、ユーザーエクスペリエンスとアプリケーションのパフォーマンスを向上させることにあります。フレームワークを選択するときは、次のことを検討してください。1。プロジェクトのサイズと複雑さ、2。チームエクスペリエンス、3。エコシステムとコミュニティサポート。

はじめに私はあなたがそれを奇妙に思うかもしれないことを知っています、JavaScript、C、およびブラウザは正確に何をしなければなりませんか?彼らは無関係であるように見えますが、実際、彼らは現代のウェブ開発において非常に重要な役割を果たしています。今日は、これら3つの間の密接なつながりについて説明します。この記事を通して、JavaScriptがブラウザでどのように実行されるか、ブラウザエンジンでのCの役割、およびそれらが協力してWebページのレンダリングと相互作用を駆動する方法を学びます。私たちは皆、JavaScriptとブラウザの関係を知っています。 JavaScriptは、フロントエンド開発のコア言語です。ブラウザで直接実行され、Webページが鮮明で興味深いものになります。なぜJavascrを疑問に思ったことがありますか


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

SublimeText3 中国語版
中国語版、とても使いやすい

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

Dreamweaver Mac版
ビジュアル Web 開発ツール
