Vue.jsはコンポーネントを通じてアイコンを処理します

Vue.jsはコンポーネントを通じてアイコンを処理します

アイコン処理ソリューション

この記録の目的は、element-plus 以外のアイコンをコンポーネントにカプセル化する方法を記録することです。仕事でアイコンの問題に対処するのに役立つことを願っています。

分析の結果、要素プラス アイコンは el-icon を通じて表示できますが、カスタム アイコンの場合は、カスタム svg アイコンを表示するためにカスタム アイコン コンポーネントが必要であることがわかりました。

コンポーネントの機能

  • 外部 SVG アイコンを表示 (外部リンク)
  • プロジェクト内にSVGアイコンを表示する

アイコンコンポーネントのパッケージ化のアイデア

表示用アイコンコンポーネント

components/SvgIcon/index.vueを作成します:

<テンプレート>
    <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;
        表示: インラインブロック;
    }
</スタイル>
​

リソースが外部リソースであるかどうかを判断する

utils/validate.jsを作成します:

/**
 * 外部リソースであるかどうかを判断する*/
エクスポート関数isExternal(path) {
  /^(https?:|mailto:|tel:)/.test(パス) を返します。
}

外部SVGアイコン表示

コンポーネント svg-icon を導入することで、icon はアイコンの外部リンクを渡します。

<span class="svg-container">
    <svg-icon icon="https://xxx.svg"></svg-icon>
</span>

プロジェクト内のSVGアイコンの処理

  • プロジェクトのsrcディレクトリにアイコンフォルダを作成し、svgアイコンファイルをインポートします。
  • iconsの下にindex.jsファイルを作成する

ファイルは2つのことを行う

  • すべてのSVGアイコンをインポート
  • SvgIconのグローバル登録を完了する

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" />

svg-sprite-loaderを使用して svg アイコンを処理する

svg-sprite-loader svgアイコンの処理に特化したwebpackloaderです。

インストール: npm i --save-dev [email protected]

vue.config.jsファイルでloaderを構成する

定数パス = 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 を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • Vue3でアイコンを使用する2つの例
  • Vueでアイコンをカスタマイズする手順
  • Vue要素プロジェクトにアイコンアイコンを導入する方法
  • Vueでカスタムアイコンを使用する方法
  • Vueプロジェクトにアイコンを導入する方法

<<:  HTML マーキータグの使用例

>>:  Docker Compose のインストールと使用手順

推薦する

Vue+Springbootでインターフェースシグネチャを実装するためのサンプルコード

1. 実装のアイデアインターフェース署名の目的は、リクエストパラメータが改ざんされていないか、リクエ...

Dockerfile を使用して Node.js サービスをデプロイする方法

Dockerfileを初期化するプロジェクトの名前が express であると仮定して、expres...

CSS の Flex レイアウトを使用してシンプルな縦棒グラフを作成する方法

以下は、Flex レイアウトを使用した棒グラフです。 HTML: <div class=&qu...

v-html レンダリング コンポーネントの問題

以前 HTML を解析したことがあるので、今日は Vue ドラッグ アンド ドロップを使用して、Ku...

HTML ページでギリシャ文字を使用する方法

ギリシャ文字は、特に数学や物理学などの科学技術分野で非常によく使用される記号列であり、特定の意味を持...

Vue3 を使用してポップアップ コンポーネントをカプセル化するのは簡単ですか?

目次最初に要約: 🌲🌲 序文: 🍬🍬公開🍬🍬 🍬🍬グローバル🍬🍬 🍬🍬ボールボックス🍬🍬 🎉🎉🎉結論...

MySQLインデックスの簡単な分析

データベース インデックスは、テーブル操作の速度を向上させることを目的としたデータ構造です。高速なラ...

MySQLで行を列に変換する方法

MySQL の行から列への操作いわゆる行から列への操作は、テーブルの行情報を列情報に変換することです...

ReactのEffectListの簡単な分析

目次EffectList コレクション最初のレンダリング時のEffectList EffectLis...

CentOS 8 インストール図 (超詳細なチュートリアル)

CentOS 8 が正式にリリースされました! CentOS は Red Hat の再配布ポリシー...

VMware pro15 インストール macOS10.13 詳細インストール図(画像とテキスト)

編集者は最近、macOS システムを使い始めたかったので、VMware に macOS イメージ シ...

Vue バッチ更新 DOM 実装手順

目次シーン紹介深い応答性トリガーゲッターDep.targetを探すゲッターセッター要約するシーン紹介...

HTML 選択オプション デフォルトの選択方法

オプションに属性 selected = "selected" を追加すると、それ...

Javascript実践におけるコマンドモードの詳しい説明

目次意味構造例カスタムショートカットキー元に戻すとやり直し録音と再生マクロ要約する意味リクエストをオ...