アイコン処理ソリューションこの記録の目的は、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 のインストールと使用手順
1. 実装のアイデアインターフェース署名の目的は、リクエストパラメータが改ざんされていないか、リクエ...
Dockerfileを初期化するプロジェクトの名前が express であると仮定して、expres...
以下は、Flex レイアウトを使用した棒グラフです。 HTML: <div class=&qu...
以前 HTML を解析したことがあるので、今日は Vue ドラッグ アンド ドロップを使用して、Ku...
ギリシャ文字は、特に数学や物理学などの科学技術分野で非常によく使用される記号列であり、特定の意味を持...
目次最初に要約: 🌲🌲 序文: 🍬🍬公開🍬🍬 🍬🍬グローバル🍬🍬 🍬🍬ボールボックス🍬🍬 🎉🎉🎉結論...
データベース インデックスは、テーブル操作の速度を向上させることを目的としたデータ構造です。高速なラ...
MySQL の行から列への操作いわゆる行から列への操作は、テーブルの行情報を列情報に変換することです...
目次EffectList コレクション最初のレンダリング時のEffectList EffectLis...
IE10 では、<input> と <input type="passw...
CentOS 8 が正式にリリースされました! CentOS は Red Hat の再配布ポリシー...
編集者は最近、macOS システムを使い始めたかったので、VMware に macOS イメージ シ...
目次シーン紹介深い応答性トリガーゲッターDep.targetを探すゲッターセッター要約するシーン紹介...
オプションに属性 selected = "selected" を追加すると、それ...
目次意味構造例カスタムショートカットキー元に戻すとやり直し録音と再生マクロ要約する意味リクエストをオ...