Vue は非常に人気のある JavaScript フレームワークで、特にフロントエンド開発で広く使用されています。 Vue には便利な機能が数多くありますが、その 1 つがサブスクライブ機能です。サブスクリプションは、Vue インスタンス内の特定のデータの変更を監視できるイベント メカニズムです。ただし、場合によってはこれらのサブスクリプションをキャンセルする必要があるため、Vue が提供するキャンセル機能が必要になります。この記事では、Vue サブスクリプションをキャンセルする方法について詳しく説明します。
Vue では、サブスクリプションはウォッチを通じて実装され、計算されます。 watch は特定のデータ属性のリスニングとコールバックを実装し、computed は 1 つ以上の属性の値に基づいて属性の値を計算します。 watch と computed を通じてサブスクリプションを定義できます。例:
data() { return { name: '', age: '', fullName: '', } }, watch: { name: function(newName) { this.fullName = 'My name is ' + newName }, age: function(newAge) { this.fullName = 'I am ' + newAge + ' years old' } } computed: { getFullName: function() { return this.fullName } }
上記のコードでは、3 つのデータ属性、つまり name、age、fullName を定義します。 watch では、名前と年齢の変化をそれぞれ監視する 2 つのコールバック関数を定義しており、名前または年齢が変化すると、コールバック関数は fullName の値を変更します。 computed では、fullName を取得するために計算プロパティ getFullName を定義します。このようにして、サブスクリプションが有効になると、名前と年齢の変更を監視し、getFullName を通じて最新の fullName を取得できます。
Vue インスタンス内のデータを購読する方法はわかりましたが、購読を中止したい場合はどうすればよいでしょうか?
Vue にはサブスクライブを解除する 2 つの方法が用意されています。1 つは watch メソッドによって返される関数を使用する方法、もう 1 つは計算された属性のキャッシュ属性を使用する方法です。
Vue では、watch メソッドは関数を返します。この関数を使用して、登録されたリスナーをキャンセルし、購読解除機能を実装できます。たとえば、親コンポーネントから子コンポーネントにプロパティを渡し、子コンポーネントでこのプロパティの変更を監視できます。
// 父组件 <template> <child-component :propA="propA" /> </template> <script> export default { data() { return { propA: '', } } } </script> // 子组件 <script> export default { props: ['propA'], watch: { propA(newPropA, oldPropA) { // do something } } } </script>
上記のコードでは、次の watch メソッドを通じて propA プロパティを監視します。子コンポーネント。親コンポーネントが propA プロパティを変更すると、子コンポーネントの watch メソッドがトリガーされ、対応するコールバックが実行されます。同時に、watch メソッドは関数を返します。コンポーネントが破棄されたときにこの関数を呼び出して、propA 属性の監視をキャンセルし、サブスクリプションをキャンセルする機能を実現できます。 、サブコンポーネント内に作成します。 watch メソッドはフック内で呼び出され、返された関数は unwatch 変数に保存されます。コンポーネントが破棄される前に、unwatch 関数を呼び出して propA 属性の監視をキャンセルし、アンサブスクリプション関数を実装します。
計算によるサブスクライブ解除
Vue では、計算プロパティを使用してプロパティの値を計算すると、コンパイラはこのプロパティのキャッシュ プロパティを作成します。このキャッシュされたプロパティは内部プロパティであり、その値は計算されたプロパティの最新の値です。このキャッシュされたプロパティにアクセスすることで、計算されたプロパティへのサブスクリプションをキャンセルでき、それによってサブスクリプション解除機能が実現されます。例:
// 子组件 <script> export default { props: ['propA'], data() { return { unwatch: null } }, created() { this.unwatch = this.$watch('propA', (newPropA, oldPropA) => { // do something }) }, beforeDestroy() { this.unwatch() } } </script>
上記のコードでは、value プロパティと doubleValue 計算プロパティを含むコンポーネントを定義します。 doubleValue プロパティにアクセスしてキャンセル関数を実装することにより、この計算されたプロパティへのサブスクリプションをキャンセルします。
結論
以上がVueでサブスクリプションをキャンセルする方法を詳しく説明した記事の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。