アイコン処理ソリューションこの記録の目的は、element-plus 以外のアイコンをコンポーネントにカプセル化する方法を記録することです。仕事でアイコンの問題に対処するのに役立つことを願っています。 分析の結果、要素プラス アイコンは el-icon を通じて表示できますが、カスタム アイコンの場合は、カスタム svg アイコンを表示するためにカスタム アイコン コンポーネントが必要であることがわかりました。 コンポーネントの機能
アイコンコンポーネントのパッケージ化のアイデア表示用アイコンコンポーネント
<テンプレート> <div v-if="isExternal" :style="styleExternalIcon" クラス="svg-external-icon svg-icon" :class="クラス名" /> <svg v-else class="svg-icon" :class="className" aria-hidden="true"> <use :xlink:href="iconName" rel="external nofollow" /> </svg> </テンプレート> <スクリプトの設定> '@/utils/validate' から { isExternal を external としてインポートします。 'vue' から {defineProps, computed} をインポートします。 const props = defineProps({ //アイコン アイコン: { タイプ: 文字列、 必須: true }, // アイコンクラス名 className: { タイプ: 文字列、 デフォルト: '' } }) /** * 外部アイコンかどうかを判定する*/ const isExternal = computed(() => external(props.icon)) /** * 外部アイコンスタイル */ const styleExternalIcon = computed(() => ({ マスク: `url(${props.icon}) 繰り返しなし 50% 50%`, '-webkit-mask': `url(${props.icon}) 繰り返しなし 50% 50%` })) /** * プロジェクトアイコン */ const iconName = computed(() => `#icon-${props.icon}`) </スクリプト> <style lang='scss' スコープ> .svgアイコン{ 幅: 1em; 高さ: 1em; 垂直位置合わせ: -0.15em; 塗りつぶし: 現在の色; オーバーフロー: 非表示; } .svg-外部アイコン { 背景色: 現在の色; マスクサイズ: カバー !important; 表示: インラインブロック; } </スタイル> リソースが外部リソースであるかどうかを判断する
/** * 外部リソースであるかどうかを判断する*/ エクスポート関数isExternal(path) { /^(https?:|mailto:|tel:)/.test(パス) を返します。 } 外部SVGアイコン表示コンポーネント svg-icon を導入することで、icon はアイコンの外部リンクを渡します。 <span class="svg-container"> <svg-icon icon="https://xxx.svg"></svg-icon> </span> プロジェクト内のSVGアイコンの処理
ファイルは2つのことを行う
index.jsコードは以下のとおりです リファレンスドキュメント 依存関係管理 | webpack 中国語ドキュメント '@/components/SvgIcon' から SvgIcon をインポートします。 // require.context() 関数を使用して独自のコンテキストを作成します const svgRequire = require.context('./svg', false, /\.svg$/) // この時点で、require インポートのリクエスト パラメータを受け入れることができる require 関数が返されます。 // この関数は 3 つのプロパティを提供し、require.keys() を通じてすべての svg アイコンを取得できます // アイコンをトラバースし、アイコンを require import 関数へのリクエストとして渡して、ローカル svg アイコンのインポートを完了します svgRequire.keys().forEach(svgIcon => svgRequire(svgIcon)) デフォルトアプリをエクスポート => { app.component('svg-icon', SvgIcon) } グローバルに登録されたプロジェクトアイコンこのファイルをmain.jsにインポートします ... // svgIcon をインポート '@/icons' から installIcons をインポートします ... アイコンをインストール(アプリ) ... 内部アイコンを使用する// ユーザー名 <svg-icon icon="user" /> // パスワード<svg-icon icon="password" />
インストール: 定数パス = require('path') 関数resolve(dir) { path.join(__dirname, dir) を返します } モジュール.エクスポート = { チェーンWebpack(config) { // svg-sprite-loader をセットアップする 構成モジュール .rule('svg') .exclude.add('src/icons' を解決します) 。終わり() 構成モジュール .rule('アイコン') .test(/\.svg$/) .include.add('src/icons' を解決します) 。終わり() .use('svg-sprite-loader') .loader('svg-sprite-loader') .オプション({ シンボルID: 'icon-[名前]' }) 。終わり() } } これは内部の svg アイコンを処理します。 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
>>: Docker Compose のインストールと使用手順
目次ログインビジネスプロセスログイン機能の実装要約するまず、エフェクトの実装プロセスを見てみましょう...
MySQL ロックの概要他のデータベースと比較すると、MySQL のロック メカニズムは比較的単純で...
最近 CSS を勉強していたとき、 2 つの CSS プロパティだけを使用して全画面スクロール効果を...
目次まず多次元配列の平坦化についてお話しましょう方法 1: flat()方法 2: 空の文字列を連結...
MySQL 8 Windows版 zipインストール手順(ダウンロードアドレス) 1. ZIPファイ...
デザイナーは心理学を理解する必要があるデザイナーが知るべき心理学という本は非常に興味深いです。まず、...
序文部門テーブルなどのデータベース内のツリー構造データの場合、部門のすべての従属部門または部門のすべ...
1. はじめにこの記事では、Docker Swarm を使用して Nebula Graph クラスタ...
1. Ubuntu Server 18.04.5 LTS システムのインストールUbuntuはデスク...
JSON 文字列を JSON オブジェクトに変換するにはどうすればいいですか? JSON.parse...
目次1. コンポーネントの紹介2. コンポーネントの内部構造とロジック1. コード組織構造2. マッ...
目次1. Docker Composeとは何か、インストールして使用する方法2. DOCleverと...
目次序文背景大きな推測パターンを見つける構造とスタイルコンポーネントの実装パラメータキーボードの種類...
JavaScriptコントロールを使用したくない場合は、次の方法を試してください。 Safariブラ...
XMLファイルは、可能な限りutf-8でエンコードする必要があります。gb2312には、?など、保存...