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 のインストールと使用手順

推薦する

CSS の画像パスの問題に関する議論 (同じパッケージ/異なるパッケージ)

CSS ファイルでは、背景を使用する、つまり背景画像を追加する必要がある場合があります。これは通常、...

MySQL サーバー 5.5 の接続失敗の解決策

mysqlに接続できない問題の解決方法を参考までに紹介します。具体的な内容は以下のとおりです。昨日は...

autoconfを使用してMakefileを生成し、プロジェクトをコンパイルする手順

序文Linux では、コンパイルとリンクには Makefile を使用する必要がありますが、適切な ...

Linux で gdb を使用してコア ファイルをデバッグする方法

1.コアファイルプログラム実行中にセグメンテーション エラー (コア ダンプ) が発生すると、プログ...

Firebug ツールを使用して iPad でページをデバッグする

iPad でページをデバッグするにはどうすればいいですか? iOS 5 をご利用の場合、iPad の...

Apache Flink の任意の Jar パッケージのアップロードにより、リモート コード実行の脆弱性が再発する問題が発生する (脆弱性警告)

脆弱性の説明Apache Flink は、分散ストリームおよびバッチ データ処理用のオープン ソース...

MySQL のファントムリード問題を解決する方法

目次序文1. ファントムリーディングとは何ですか? 2. ファントムリーディングの問題点は何ですか?...

Dockerコンテナデータボリュームの原理と使用法の分析

コンテナデータボリュームとはデータがコンテナ内にある場合、コンテナを削除するとデータは失われます。例...

Linux の grep コマンドと egrep コマンドの詳細な説明

反復/egrep構文: grep [-cinvABC] 'word' ファイル名-c...

CentOS7 ファイアウォール操作コマンドの完全なリスト

目次インストール: 1. ファイアウォールの基本的な使い方2. ファイアウォールd-cmdを設定する...

Dockerを使用してコンテナリソースを制限する方法

覗き見の問題サーバーでは、IIS サービスが複数のサイトを展開していると仮定すると、サイトの 1 つ...

ページ切り替え効果を実現するJSコード

この記事の例では、ページ切り替え効果を実現するためのJSコードの具体的なコードを参考までに共有してい...

jQueryはアコーディオン効果を実装します

この記事では、アコーディオンを実装するためのjQueryの具体的なコードを参考までに紹介します。具体...

MySQL binlog の解析

目次1. binlogの紹介2. Binlog関連のパラメータ3. バイナリログの内容を分析するIV...

別の種類の「キャンセル」ボタン

「キャンセル」ボタンは必要な操作プロセスの一部ではなく、デザイン上の主要な要素として表示されません...