Vue カプセル化コンポーネント ツール $attrs、$listeners の使用

Vue カプセル化コンポーネント ツール $attrs、$listeners の使用

序文

複数レベルのコンポーネントのネストでデータ転送が必要な場合、一般的に使用される方法は vuex を使用することです。しかし、中間処理なしでデータを渡すだけで、処理に vuex を使用するのは、少しやりすぎです。したがって、通常は inheritAttrs と一緒に使用される 2 つの属性、$attrs と $listeners があります。

$属性

親コンポーネントからカスタム子コンポーネントに渡されるプロパティは、プロパティ レシーバーがない場合、子コンポーネント内の最も外側のタグに自動的に設定されます。クラスとスタイルの場合は、最も外側のタグのクラスとスタイルがマージされます。

子コンポーネントが親コンポーネントから渡された非プロパティ属性を継承したくない場合は、inheritAttrs を使用して継承を無効にし、v-bind="$attrs" を通じて目的のタグに渡された外部の非プロパティ属性を設定できますが、これによってクラスとスタイルは変更されません。

inheritAttrs 属性の公式ウェブサイト リンク

2.4.0 新機能

タイプ: ブール値

デフォルト値: true

詳細:

デフォルトでは、プロパティとして認識されない親スコープの属性バインディングは「フォールバック」され、子コンポーネントのルート要素に通常の HTML 属性として適用されます。ターゲット要素または別のコンポーネントをラップするコンポーネントを作成する場合、これが必ずしも期待どおりの動作になるとは限りません。 inheritAttrs を false に設定すると、このデフォルトの動作は削除されます。これらの属性は、インスタンス プロパティ $attrs (これも 2.4 の新機能) を通じて有効にすることができ、v-bind を通じてルート以外の要素に明示的にバインドできます。

注: このオプションはクラスとスタイルのバインディングには影響しません。

例:

親コンポーネント

<テンプレート>
  <私の入力
      必須
      placeholder="コンテンツを入力してください"
      タイプ="テキスト"
      クラス="テーマダーク"
  />
</テンプレート>

<スクリプト>
MyInput を './child' からインポートします。
エクスポートデフォルト{
  名前: '親'、
  コンポーネント:
    マイインプット
  }
}
</スクリプト>

サブコンポーネント

<テンプレート>
  <div>
    <入力
        v-bind="$attrs"
        クラス="フォームコントロール"
    />
  </div>
</テンプレート>

<スクリプト>
エクスポートデフォルト{
  名前: 'MyInput',
  継承属性: false
}
</スクリプト>

子コンポーネントは親コンポーネントから渡された値を受け入れず、バインドもしませんが、属性v-bind="$attrs"を使用すると、自動的に受け入れてバインドします。

継承属性: false

継承属性: true

$listeners (公式説明)

listeners: 親スコープ内の v-on イベント リスナーが含まれます (.native 修飾子なし)。これは、v-on="$listeners" を介して内部コンポーネントに渡すことができます。これは、より高レベルのコンポーネントを作成するときに非常に便利です。

まず、コードを見てみましょう。ここでは、フォーカス イベントと入力イベントのみを例として取り上げます。

// 親コンポーネント <テンプレート>
  <私の入力
      必須
      プレースホルダー
      クラス="テーマダーク"
      @focue="フォーカスオン"
      @input="入力時"
  >
  </my-input>
</テンプレート>
<スクリプト>
MyInput を './child' からインポートします。
エクスポートデフォルト{
  コンポーネント:
    マイインプット
  },
  メソッド: {
    オンフォーカス(e) {
      console.log(e.target.value)
    },
    オン入力(e) {
      console.log(e.target.value)
    }
  }
}
</スクリプト>
// サブコンポーネント <テンプレート>
  <div>
    <入力
        タイプ="テキスト"
        v-bind="$attrs"
        クラス="フォームコントロール"
        @focus="$emit('focus', $event)"
        @input="$emit('input', $event)"
    />
  </div>
</テンプレート>

<スクリプト>
エクスポートデフォルト{
  名前: 'MyInput',
  継承属性: false
}
</スクリプト>

このようにネイティブ イベントをバインドするのは非常に面倒です。すべてのネイティブ イベントをバインドする必要がありますが、v-on="$listeners" を使用すると、多くの手間が省けます。

 <入力
        タイプ="テキスト"
        v-bind="$attrs"
        クラス="フォームコントロール"
+ v-on="$リスナー"
- @focus="$emit('focus', $event)"
- @input="$emit('input', $event)"
    />

この1行のコードで、すべてのネイティブイベントをバインドする問題を解決できます。

使用シナリオ

コンポーネントが値を渡すときに使用します。祖父は父コンポーネントに値を渡し、父コンポーネントは $attrs を通じて父の props にないすべての属性を取得します。父コンポーネントは孫コンポーネントに $attrs と $listeners をバインドし、孫コンポーネントが祖父から渡された値を取得し、祖父で定義されたメソッドを呼び出すことができるようにします。

一部の UI ライブラリの二次パッケージ化に使用されます。たとえば、element-ui のコンポーネントが独自の使用シナリオを満たせない場合は、二次パッケージ化されますが、独自のプロパティとメソッドを保持する必要があります。この場合、$attrs と $listners は最適なソリューションです。

要約する

Vue カプセル化コンポーネントの強力なツールである $attrs と $listeners の使用に関するこの記事はこれで終わりです。Vue カプセル化コンポーネントの $attrs と $listeners の使用に関する詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • vue2.xの$attrsと$listenersについて簡単に説明します。
  • vue $attrs と $listeners の使い方と違い
  • Vue で $props、$attrs、$listeners を使用する方法の詳細な説明
  • Vue で $attrs と $listeners を使用するチュートリアル
  • Vue $attrs と inheritAttr を使用してボタンを無効にした効果を実現する
  • Vue コンポーネント通信における $attrs と $listeners の実装原則の分析
  • vue $attrs の使用に関する包括的な分析

<<:  CSS3.0 でネオンボタンアニメーション効果を実装するためのサンプルコード

>>:  ウェブページの再設計の7つの主要要素 ウェブページの再設計の7つの主要要素を共有する

推薦する

Nest.js パラメータ検証とカスタム戻りデータ形式の詳細な説明

0x0 パラメータ検証Nest.jsでは、パラメータ検証業務のほとんどをパイプライン方式で実装してい...

MySQLストレージフィールドタイプのクエリ効率についての簡単な理解

検索パフォーマンスは最速から最遅まで次のとおりです (私が聞いたところによると)。 1 番目: ti...

MySQL 文字列連結と null 値の設定のためのインスタンス メソッド

#文字列連結 concat(s1,s2); テーブル内の last_name と first_nam...

JavaScript オブジェクトからプリミティブ値への変換の詳細な説明

目次オブジェクトプロトタイプの値()オブジェクトプロトタイプtoString()シンボル.toPri...

HTML テーブル マークアップ チュートリアル (2): テーブル境界属性 BORDER

デフォルトでは、テーブルの境界線は 0 ですが、テーブルの境界線を設定できます。基本的な構文<...

MySQL の基本: グループ化関数、集計関数、グループ化クエリの詳細な説明

目次1. 使い方が簡単2. DISTINCTを使用して重複を削除する3. COUNT()の詳細な紹介...

Vue が値を返してフォームを動的に生成し、データを送信する仕組みの詳細な説明

目次解決された主な問題1. バックエンドから返され、バックエンドに送信されるデータは、次の形式になり...

Dockerの一般的なコマンドとヒントのまとめ

インストールスクリプトUbuntu / CentOS Debian のインストールに問題があるようで...

Linux カーネル デバイス ドライバー システム コールに関する注意事項

/**************************** * システムコール**********...

Vue lazyload 画像遅延読み込み例の詳細な説明

ドキュメント: https://github.com/hilongjw/vue-lazyload 1...

ElementUI コンポーネント el-dropdown (落とし穴)

選択して変更: クリックすると現在の値が表示され、ページ UI が表示され、CSS スタイルが変更さ...

Vue+el-tableはセルの結合を実現します

この記事の例では、参考までにセルの結合を実現するためのel-tableの具体的なコードを共有していま...

vue v-for ループ オブジェクトの属性

目次1. ループオブジェクト内の値2. ループオブジェクト3. キーと値のループ1. ループオブジェ...

JavaScript 関数構文の説明

目次1. 通常の機能2. 矢印関数3. データパケットJSON 4. オブジェクト5. 約束6. 非...

LeetCode の SQL 実装 (196. 重複するメールボックスを削除する)

[LeetCode] 196.重複したメールを削除するSQL クエリを記述して、Person とい...