ホームページ > ウェブフロントエンド > Vue.js > vue コンポーネントの 3 つの API (prop、slot、event) についての深い理解

vue コンポーネントの 3 つの API (prop、slot、event) についての深い理解

青灯夜游
リリース: 2021-11-23 19:14:06
転載
2334 人が閲覧しました

コンポーネントがどれほど複雑であっても、コンポーネントはプロップ、イベント、スロットで構成されている必要があります。次の記事では、vue コンポーネントの prop、slot、event を理解し、これら 3 つの API を記述する方法について説明します。

vue コンポーネントの 3 つの API (prop、slot、event) についての深い理解

質問の紹介

次のようなシナリオに遭遇したことはありますか: 開発中に、特に一般的な表示や関数に遭遇し、それらを抽出してカプセル化したいと考えています。他の開発者が使用するために共有される独立したコンポーネント。

コンポーネントをカプセル化するには、まずコンポーネントの基本構成を理解します。コンポーネントがどれほど複雑であっても、コンポーネントはプロップ、イベント、スロットで構成されている必要があります。コンポーネントを作成するプロセスは、これら 3 つの API を設計するプロセスです。同様に、他の人が作成したコンポーネントを読みたい場合も、これら 3 つの API を使用してコンポーネントをすばやく理解することができます。 [関連する推奨事項: "vue.js チュートリアル "]

では、prop、event、slot という 3 つの API をどのように記述すればよいでしょうか?

プロパティ prop

prop は、コンポーネントが受け入れることができるプロパティを定義するために使用されます。

vue の公式 Web サイトを読むと、prop は配列またはオブジェクトで記述できることがわかります。便宜上、厳密ではない prop の配列記述メソッドを直接使用する人が多いですが、一般的なコンポーネントを記述する場合は、できる限り prop のオブジェクト記述メソッドを使用する必要があります。

次のコードが表示されます:

app.component('my-component', {
  props: {
    // 基础的类型检查 (`null` 和 `undefined` 会通过任何类型验证)
    propA: Number,
    // 多个可能的类型
    propB: [String, Number],
    // 必填的字符串
    propC: {
      type: String,
      required: true
    },
    // 带有默认值的数字
    propD: {
      type: Number,
      default: 100
    },
    // 带有默认值的对象
    propE: {
      type: Object,
      // 对象或数组默认值必须从一个工厂函数获取
      default() {
        return { message: 'hello' }
      }
    },
    // 自定义验证函数
    propF: {
      validator(value) {
        // 这个值必须匹配下列字符串中的一个
        return ['success', 'warning', 'danger'].includes(value)
      }
    },
    // 具有默认值的函数
    propG: {
      type: Function,
      // 与对象或数组默认值不同,这不是一个工厂函数 —— 这是一个用作默认值的函数
      default() {
        return 'Default function'
      }
    }
  }
})
ログイン後にコピー

prop がオブジェクト書き込みメソッドを使用していることが誰でもわかると思います。受信した属性が正しいかどうかを確認し、適切なタイミングでプロンプトを表示できます。これは次のとおりです。これは、独立したコンポーネントを作成する場合に特に便利です。

vue は一方向のデータ フロー原則に従う必要があるため、prop 値を変更する必要はなく、他のソリューションを使用する必要があります。

prop 値を変更するための一般的なソリューション

1. Prop は初期値を渡し、それをデータに割り当てます

props: ['initialCounter'],
data() {
  return {
    counter: this.initialCounter
  }
}
ログイン後にコピー

2. 属性を計算して prop 値を取得します

props: ['size'],
computed: {
  normalizedSize() {
    return this.size.trim().toLowerCase()
  }
}
ログイン後にコピー

スロット スロット

スロット スロットは、

<todo-button>
  Add todo
</todo-button>
ログイン後にコピー
<!-- todo-button 组件模板 -->
<button class="btn-primary">
  <slot></slot>
</button>
ログイン後にコピー

などのコンポーネントのコンテンツを配布するために使用されます。レンダリングすると、次のような [Add todo] に置き換えられます。

<!-- 渲染 HTML -->
<button class="btn-primary">
  Add todo
</button>
ログイン後にコピー

これはスロットの最も基本的な使い方です。名前付きスロットから派生したものです。その名の通り、スロットを区別するためのものです。複数のスロットを設定することができます。例:

<div class="container">
  <header>
    <slot name="header"></slot>
  </header>
  <main>
    <slot></slot>
  </main>
  <footer>
    <slot name="footer"></slot>
  </footer>
</div>
ログイン後にコピー

スロットのバックアップ情報の設定に遭遇することがあります。その場合は、次のように使用できます:

<button type="submit">
  <slot>Submit</slot>
</button>
ログイン後にコピー

スロットのバックアップ情報は、Submit

イベント イベント

イベント名です。

子コンポーネントがデータを変更したとき、親コンポーネントに通知したいときは、次のようにイベントイベントを使用します。子コンポーネントが呼び出すときのイベント名はキャメルケース名ですが、親コンポーネントのイベント名はケバブケース名です。

カスタム イベント

// 子组件
this.$emit(&#39;myEvent&#39;)
ログイン後にコピー

などの Emits オプションを使用してイベントをカスタマイズできます。カスタム イベントが同じである場合に注意してください。クリックなどのネイティブ イベントとして使用した場合、カスタム イベントがネイティブ イベントを置き換えます

#コンポーネントの構成

##公式 Web サイトから画像を紹介します

# ページは、コンポーネントで構成されるツリーと同等です。各コンポーネントには、親コンポーネントとサブコンポーネントがある場合があります。

属性 prop を使用すると、親コンポーネントがプロパティをサブコンポーネントに渡すことができ、イベント イベントを使用すると、サブコンポーネントが親コンポーネントに情報を渡すことができます。スロット スロットは、コンテンツ

を配布するために親コンポーネントによって使用されます。 vue コンポーネントの 3 つの API (prop、slot、event) についての深い理解

概要

これら 3 つの API に加えて、コンポーネントにはライフサイクル、ミックスイン、計算されたプロパティなどの他のコンテンツもあります。開発にはこの 3 つの API で十分です。これら 3 つの API をマスターしたら、あとはコンポーネントの対話ロジックを分離し、さまざまな機能をさまざまなサブコンポーネントに分散してみて、コンポーネント ツリーを構築するだけです。

プログラミング関連の知識について詳しくは、プログラミング入門

をご覧ください。 !

以上がvue コンポーネントの 3 つの API (prop、slot、event) についての深い理解の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:juejin.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート