ホームページ > ウェブフロントエンド > Vue.js > Vue3 SFC および TSX を使用してサブコンポーネント内の関数を呼び出す方法

Vue3 SFC および TSX を使用してサブコンポーネント内の関数を呼び出す方法

王林
リリース: 2023-05-11 14:58:13
転載
1496 人が閲覧しました

開発では、サブコンポーネントの参照を取得し、サブコンポーネントで定義されたメソッドを呼び出すという要件に遭遇することがあります。フォームコンポーネントがカプセル化されている場合、親コンポーネントでこのフォームコンポーネントの参照を呼び出し、このフォームコンポーネントの検証フォーム関数またはリセットフォーム関数を呼び出す必要があります。この関数を実装するには、まず親コンポーネントが子コンポーネントで呼び出す必要がある関数を公開し、次に親コンポーネントに移動して子コンポーネントの参照を取得し、最後に子コンポーネントの参照を通じて子コンポーネントによって公開されたメソッドを呼び出します。子コンポーネント。

1 サブコンポーネントの公開方法

1.1 SFC (.vue) の公開方法

.vue を使用して定義されたコンポーネントでは、defineExpose() メソッドがセットアップで提供されます。コンポーネント内のメソッドを親コンポーネントに追加します。

サブコンポーネントのデモ-コンポーネント-sfc.vue の作成:

<template>
  <el-button type="primary" @click="demoFun(&#39;child&#39;)">demo component sfc</el-button>
</template>

<script lang="ts" setup name="demo-component-sfc">
const demoFun = (str: string) => {
  console.log(&#39;demo component sfc&#39;, str)
}
// 使用 defineExpose 暴露组件内部的方法
defineExpose({ demoFun })
</script>
ログイン後にコピー

1.2 TSX (.tsx) 公開メソッド

.tsx メソッドを使用して定義されたコンポーネントも、パラメータ コンテキスト の Expose() メソッドは、コンポーネントのコンテンツを公開します。

サブコンポーネントのデモ-コンポーネント-tsx.tsx の作成:

import { defineComponent } from &#39;vue&#39;

export default defineComponent({
  name: &#39;demo-component-tsx&#39;,
  setup (props, context) {
    const demoFun = (str: string) => {
      console.log(&#39;demo component tsx&#39;, str)
    }

    // 使用 expose 暴露组件内部的方法
    context.expose({ demoFun })

    return () => (
      <el-button type="primary" onClick={() => demoFun(&#39;child&#39;)}>demo component tsx</el-button>
    )
  }
})
ログイン後にコピー
ログイン後にコピー

2 親コンポーネントは、サブコンポーネントのメソッドを呼び出します。

2.1 SFC (.vue) 呼び出し

.vue ファイル内のコンポーネント参照を取得するには、まず ref 変数を定義し、次にサブコンポーネントの ref 属性を設定します。 ref 属性値は変数名と一致している必要があります。

import { defineComponent } from &#39;vue&#39;

export default defineComponent({
  name: &#39;demo-component-tsx&#39;,
  setup (props, context) {
    const demoFun = (str: string) => {
      console.log(&#39;demo component tsx&#39;, str)
    }

    // 使用 expose 暴露组件内部的方法
    context.expose({ demoFun })

    return () => (
      <el-button type="primary" onClick={() => demoFun(&#39;child&#39;)}>demo component tsx</el-button>
    )
  }
})
ログイン後にコピー
ログイン後にコピー

上記のコードに示すように、最初のサブコンポーネントの ref 属性値は sfcRef で、定義された変数名も sfcRef です。親コンポーネントでは、sfcRef を使用して子コンポーネントの demoFun メソッドを呼び出すことができます。

2.2 TSX (.tsx) 呼び出し

.tsx でコンポーネントの参照を取得する方が簡単です。最初に ref 変数を定義し、次にその変数をその変数の ref 属性に設定します。サブコンポーネント。

import { defineComponent, ref } from &#39;vue&#39;
import DemoComponentSfc from &#39;@/components/ref/demo-component-sfc.vue&#39;
import DemoComponentTsx from &#39;@/components/ref/demo-component-tsx&#39;

export default defineComponent({
  name: &#39;demo-ref-tsx&#39;,
  setup () {
    const sfcRef = ref()

    const onBtnClick1 = () => {
      if (sfcRef.value) {
        sfcRef.value && sfcRef.value.demoFun(&#39;parent&#39;)
      }
    }

    const tsxRef = ref()

    const onBtnClick2 = () => {
      if (tsxRef.value) {
        tsxRef.value && tsxRef.value.demoFun(&#39;parent&#39;)
      }
    }
    return () => (
      <>
        <div>
          <DemoComponentSfc ref={sfcRef} />
          <el-button onClick={onBtnClick1}>parent button</el-button>
        </div>

        <div >
          <DemoComponentTsx ref={tsxRef} />
          <el-button onClick={onBtnClick2}>parent button</el-button>
        </div>
      </>
    )
  }
})
ログイン後にコピー

この 2 つは同じ効果をもたらします:

Vue3 SFC および TSX を使用してサブコンポーネント内の関数を呼び出す方法

以上がVue3 SFC および TSX を使用してサブコンポーネント内の関数を呼び出す方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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