ナビゲーションバーコンポーネントをVueでカプセル化する

ナビゲーションバーコンポーネントをVueでカプセル化する

はじめに:ナビゲーション バーなどのコンポーネント ベースのアイデアを使用して機能モジュールを完全にカプセル化すると、開発アイデアと効率の両方に多くの利点があります。開発では、コンポーネント ベースの開発アイデアを可能な限り使用し、すべてのコードを同じ .vue ファイルに記述しないようにする必要があります。これにより、コードの可読性が大幅に向上します。

ナビゲーションバーのカプセル化

主なアイデアは、赤い部分をコンポーネントとして扱うことです。赤い部分は画像とテキストが異なるだけなので、同じコンポーネントにカプセル化し、画像情報とテキスト情報をコンポーネントに渡します (スロットを使用できます)。

//タブバーアイテム.vue
<テンプレート>
  <div class="tabBarItem" @click="tabBarItemClick">
    <div v-if="!isActive">
      <スロット名="アイテムアイコン"></スロット>
    </div>
    <div v-else>
      <スロット名="アイテムアイコンアクティブ"></スロット>
    </div>
    <div:style="isActiveColor"> は、
      <スロット名="アイテムテキスト"></スロット>
    </div>
  </div>
</テンプレート>

<スクリプト>
エクスポートデフォルト{
  名前:"タブバーアイテム",
  小道具:{
    パス:文字列、
    アクティブカラー:{
      タイプ:文字列、
      デフォルト:"ピンク"
    }
  },
  計算:{
    アクティブ:{
      得る(){
        this.$route.path.indexOf(this.path)!=​​=-1 を返します。
      },
      セット(){}
    },
    isActiveColor(){
      this.isActive?{color:this.activeColor}:{} を返します。
    }
  },
  方法:{
    タブバーアイテムクリック(){
      this.$router.push(this.path);
    }
  }
}
</スクリプト>

<スタイルスコープ>
.tabBarItem{
  フレックス: 1;
  フォントサイズ: 12px;
}
.tabBarItem画像{
  上マージン: 3px;
  幅: 24px;
  パディング下部:3px;
}
</スタイル>

次のステップは、これら 4 つのオプションを同じ場所に配置するコンテナーをカプセル化することです。

//タブバー.vue
<テンプレート>
  <div class="tabBar">
    <スロット></スロット>
  </div>
</テンプレート>

<スクリプト>
エクスポートデフォルト{
  名前:"タブバー"
}
</スクリプト>

<スタイルスコープ>
.タブバー{
  ディスプレイ: フレックス;
  高さ: 49px;
  位置: 固定;
  左: 0;
  右: 0;
  下部: 0;
  テキスト配置: 中央;
  ボックスの影: 0px -1px 1px rgba(100, 100, 100, .1);
  背景色: #f6f6f6;
}

</スタイル>

次のステップでは、これを使用して、それぞれの TabBarItem スロットに異なる画像とテキスト情報を書き込むことです。

//メインタブバー.vue
<テンプレート>
  <div class="mainTabBar">
    <タブバー>
      <タブバー項目パス="/home" activeColor="#ff8198">
        <img src="~assets/img/tabbar/home.svg" alt="" slot="item-icon">
        <img src="~assets/img/tabbar/home_active.svg" alt="" slot="item-icon-active">
        <div slot="item-text">ホーム</div>
      </タブバー項目>
      <タブバー項目パス="/カテゴリ" activeColor="#ff8198">
        <img src="~assets/img/tabbar/category.svg" alt="" slot="item-icon">
        <img src="~assets/img/tabbar/category_active.svg" alt="" slot="item-icon-active">
        <div slot="item-text">カテゴリー</div>
      </タブバー項目>
      <タブバーアイテムパス="/カート" activeColor="#ff8198">
        <img src="~assets/img/tabbar/shopcart.svg" alt="" slot="アイテムアイコン">
        <img src="~assets/img/tabbar/shopcart_active.svg" alt="" slot="item-icon-active">
        <div slot="item-text">ショッピングカート</div>
      </タブバー項目>
      <タブバー項目パス="/プロファイル" activeColor="#ff8198">
        <img src="~assets/img/tabbar/profile.svg" alt="" slot="item-icon">
        <img src="~assets/img/tabbar/profile_active.svg" alt="" slot="item-icon-active">
        <div slot="item-text">マイ</div>
      </タブバー項目>
    </タブバー>
  </div>
</テンプレート>

<スクリプト>
「components/common/tabbar/TabBar」からTabBarをインポートします。
「components/content/tabbar/TabBarItem」からTabBarItemをインポートします。
エクスポートデフォルト{
  名前:"メインタブバー",
  コンポーネント:{
    タブバー、
    タブバーアイテム
  }
}

</スクリプト>
<スタイル>

</スタイル>

ナビゲーションバーは一般的にホームページで使用されるため、このナビゲーションバーをApp.vueに配置します。

<テンプレート>
  <div id="アプリ">
    <メインタブバー></メインタブバー>
  </div>
</テンプレート>

<スクリプト>
「components/content/tabbar/MainTabBar」からMainTabBarをインポートします。
エクスポートデフォルト{
  名前: 'アプリ'、
  コンポーネント:{
    メインタブバー
  }
}

まとめ:ナビゲーション バーを書くのに 3 つのファイルを使用するようです。面倒に思えるかもしれませんが、コードの可読性が大幅に向上します。プロジェクトの他の場所でナビゲーション バーを使用する必要がある場合は、MainTabBar に似たファイルを作成し、必要な画像とテキストをその中に書き込むだけです。他のプロジェクトで使用する場合でも、ファイルを直接コピーして直接使用できます。CSS スタイルを記述する必要さえないため、開発効率が大幅に向上します。

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • 5 分で vue-cli3 を使用してプロジェクトを作成する方法を説明します (初心者向けガイド)
  • Vueプロジェクトでlessを使用するためのヒント
  • Vue プロジェクトで TypeScript クラスを適用する方法
  • Vue.jsでタブ切り替えと色変更操作を実装する解説
  • Vuex全体のケースの詳細な説明
  • Vueのトグルボタンをクリックしてボタンを有効にし、無効にします。
  • Vueコンポーネント通信方法事例まとめ
  • Vue.js スロットにおけるスコープ付きスロットの使用法の詳細な説明
  • Vue コードの読みやすさに関するいくつかの提案

<<:  MySQL ルートパスワードエラー番号 1045 の解決方法

>>:  Dockerコンテナのホスト間マルチネットワークセグメント通信ソリューションの詳細説明

推薦する

Windows Server 2008R2、2012、2016、2019 の違い

目次共通バージョンの紹介共通バージョンのダウンロードアドレスとインストール以下に簡単な違いを示します...

XHTML の IE 条件付きコメント

<br />条件付きコメントはIEシリーズ製品上でXHTMLコード処理を分離して行うこと...

Zabbix redis 自動ポート検出スクリプトは json 形式を返します

自動検出を行う際には、ポートなどの情報を取得してjson形式で返すスクリプトが必ず存在します。Red...

Office ファイルのオンライン プレビュー用の Vue サンプル コード

最近、電子アーカイブに取り組んでおり、バックエンドではファイルの Huawei Cloud OSS ...

jsはキャンバスに基づいて時計コンポーネントを実装します

圧縮アップロード画像、スクラッチカード、ポスター作成、チャートプラグインなど、フロントエンド開発にお...

VueはSplitを使用して、ユニバーサルドラッグアンドスライドパーティションパネルコンポーネントをカプセル化します。

目次序文始める基本レイアウトデータバインディングイベントバインディング最適化ジッター問題を最適化する...

TypeScriptにおけるunknownとanyの違いについて詳しく説明します

目次序文1. 不明 vs 任意2. 未知とあらゆるもののメンタルモデル3. まとめ要約する序文any...

Vue のスロットとフィルターの詳細な説明

目次スロットスロットとは何ですか?スロットの内容コンパイルスコープフォールバックコンテンツ名前付きス...

CSS の高さの崩壊問題の解決

1. 崩壊度が高いドキュメント フローでは、親要素の高さはデフォルトで子要素によって拡張されます。つ...

Vue+echarts でプログレスバーのヒストグラムを実現

この記事では、プログレスバーヒストグラムを実現するためのvue+echartsの具体的なコードを参考...

Linux で MySQL をインストールする簡単な方法

Linux に MySQL をインストールする方法をオンラインで検索すると、多くの方法が表示されまし...

HTTPS の有効化に関する経験の共有

国内のネットワーク環境が悪化し続ける中、さまざまな改ざんや乗っ取りが後を絶たず、サイト全体をHTTP...

React 純粋関数コンポーネント setState がページ更新を更新しない問題の解決方法

目次問題の説明:原因分析:解決:補足: Reactでは、フックが使用されている場合、useState...

JS 非同期コードユニットテストの魔法 Promise

目次序文プロミスチェーンMDN エラー連鎖デフォルト処理略語非同期待機序文この記事を書いた理由は、ユ...

CocosCreator ソースコードの解釈: エンジンの起動とメインループ

目次序文準備行く!文章プロセスを開始するメインループまとめ要約する序文準備皆さんは、こんなことを考え...