Vue 開発で発生した複数レベルのメニュー表示の問題に対処する方法
Vue 開発プロセス中に、複数レベルのメニューを表示する必要があるシナリオに遭遇することがよくあります。マルチレベルメニューの表示の問題は、フロントエンド UI の問題だけでなく、データの構造設計や対話方法の選択にも関係します。この記事では、メニューが多階層に表示される場合の対処方法を紹介します。
1. データ構造の設計
マルチレベルのメニュー表示の問題に対処する場合は、まずメニューの階層関係を保存する適切なデータ構造を設計する必要があります。一般的に使用されるデータ構造はツリー構造です。ツリー構造は、ルート ノードと複数の子ノードで構成され、各子ノードには独自の子ノードが存在する場合もあります。 Vue では、オブジェクトのネストを使用してツリー構造を表現できます。
たとえば、3 レベルのメニューの場合、次のデータ構造を定義できます:
{ label: '一级菜单', children: [ { label: '二级菜单1', children: [ { label: '三级菜单1' }, { label: '三级菜单2' } ] }, { label: '二级菜单2', children: [ { label: '三级菜单3' }, { label: '三级菜单4' } ] } ] }
2. 再帰表示メニュー
Vue では、再帰コンポーネントを使用できます。多階層メニューを表示します。再帰コンポーネントは、コンポーネント内にそれ自体を含む特別なコンポーネントです。
まず、単一のメニュー項目を表示するメニュー コンポーネント (Menu) を作成する必要があります。メニュー コンポーネントは、現在のメニュー項目のデータを表すために使用される item
という名前のプロパティを受け取ります。
<template> <div> <span>{{ item.label }}</span> <ul v-if="item.children"> <li v-for="child in item.children" :key="child.label"> <menu :item="child"></menu> </li> </ul> </div> </template> <script> export default { name: 'Menu', props: ['item'] } </script>
次に、親コンポーネントの再帰コンポーネントを使用して、複数レベルのメニューを表示します。親コンポーネントは、メニュー データを表すために menuData
という名前のプロパティを受け取る必要があります。
<template> <div> <menu v-for="item in menuData" :key="item.label" :item="item"></menu> </div> </template> <script> import Menu from './Menu' export default { components: { Menu }, props: ['menuData'] } </script>
3. メニュー インタラクションの処理
通常、メニュー項目をクリックして下位レベルのメニューを展開したり、メニュー項目を選択したりするなど、メニュー内でいくつかのインタラクティブな操作を処理する必要があります。 、など。これらの対話型操作は、メニュー コンポーネントに対応するイベント処理メソッドを追加することで実現できます。
メニュー コンポーネントでは、クリック イベント clickMenu
を追加し、このメソッドでメニュー項目の展開状態を切り替えることができます。
<template> <div> <span @click="clickMenu">{{ item.label }}</span> <ul v-if="item.children && item.open"> <li v-for="child in item.children" :key="child.label"> <menu :item="child"></menu> </li> </ul> </div> </template> <script> export default { name: 'Menu', props: ['item'], methods: { clickMenu() { this.item.open = !this.item.open } } } </script>
親コンポーネントでは、選択イベント selectMenu
を追加し、このメソッドでメニュー項目の選択ロジックを処理できます。
<template> <div> <menu v-for="item in menuData" :key="item.label" :item="item" @selectMenu="selectMenu"></menu> </div> </template> <script> import Menu from './Menu' export default { components: { Menu }, props: ['menuData'], methods: { selectMenu(item) { console.log(item.label + '被选中') } } } </script>
上記の方法により、Vue 開発で遭遇する複数レベルのメニュー表示の問題に簡単に対処できます。適切なデータ構造を設計し、再帰コンポーネントを使用してメニューを表示し、メニューの対話を処理すると、マルチレベル メニューの表示がより柔軟になり、保守が容易になります。
以上がVue開発における多階層メニュー表示の問題の解決策の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

PHPは主に手順プログラミングですが、オブジェクト指向プログラミング(OOP)もサポートしています。 Pythonは、OOP、機能、手続き上のプログラミングなど、さまざまなパラダイムをサポートしています。 PHPはWeb開発に適しており、Pythonはデータ分析や機械学習などのさまざまなアプリケーションに適しています。

PHPは1994年に発信され、Rasmuslerdorfによって開発されました。もともとはウェブサイトの訪問者を追跡するために使用され、サーバー側のスクリプト言語に徐々に進化し、Web開発で広く使用されていました。 Pythonは、1980年代後半にGuidovan Rossumによって開発され、1991年に最初にリリースされました。コードの読みやすさとシンプルさを強調し、科学的コンピューティング、データ分析、その他の分野に適しています。

PHPはWeb開発と迅速なプロトタイピングに適しており、Pythonはデータサイエンスと機械学習に適しています。 1.PHPは、単純な構文と迅速な開発に適した動的なWeb開発に使用されます。 2。Pythonには簡潔な構文があり、複数のフィールドに適しており、強力なライブラリエコシステムがあります。

PHPは、多数のWebサイトとアプリケーションをサポートし、フレームワークを通じて開発ニーズに適応するため、近代化プロセスで依然として重要です。 1.PHP7はパフォーマンスを向上させ、新機能を紹介します。 2。Laravel、Symfony、Codeigniterなどの最新のフレームワークは、開発を簡素化し、コードの品質を向上させます。 3.パフォーマンスの最適化とベストプラクティスは、アプリケーションの効率をさらに改善します。

phphassiblasifly-impactedwebdevevermentandsbeyondit.1)itpowersmajorplatformslikewordpratsandexcelsindatabase interactions.2)php'sadaptableability allowsitale forlargeapplicationsusingframeworkslikelavel.3)

PHPタイプは、コードの品質と読みやすさを向上させるためのプロンプトがあります。 1)スカラータイプのヒント:php7.0であるため、基本データ型は、int、floatなどの関数パラメーターで指定できます。 3)ユニオンタイプのプロンプト:PHP8.0であるため、関数パラメーターまたは戻り値で複数のタイプを指定することができます。 4)Nullable Typeプロンプト:null値を含めることができ、null値を返す可能性のある機能を処理できます。

PHPでは、クローンキーワードを使用してオブジェクトのコピーを作成し、\ _ \ _クローンマジックメソッドを使用してクローン動作をカスタマイズします。 1.クローンキーワードを使用して浅いコピーを作成し、オブジェクトのプロパティをクローン化しますが、オブジェクトのプロパティはクローニングしません。 2。\ _ \ _クローン法は、浅いコピーの問題を避けるために、ネストされたオブジェクトを深くコピーできます。 3.クローニングにおける円形の参照とパフォーマンスの問題を避けるために注意し、クローニング操作を最適化して効率を向上させます。

PHPはWeb開発およびコンテンツ管理システムに適しており、Pythonはデータサイエンス、機械学習、自動化スクリプトに適しています。 1.PHPは、高速でスケーラブルなWebサイトとアプリケーションの構築においてうまく機能し、WordPressなどのCMSで一般的に使用されます。 2。Pythonは、NumpyやTensorflowなどの豊富なライブラリを使用して、データサイエンスと機械学習の分野で驚くほどパフォーマンスを発揮しています。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

メモ帳++7.3.1
使いやすく無料のコードエディター
