ホームページ >ウェブフロントエンド >Vue.js >カスタムコンポーネントでv-modelを使用するにはどうすればよいですか? .sync 修飾子の使用シナリオについて話しましょう

カスタムコンポーネントでv-modelを使用するにはどうすればよいですか? .sync 修飾子の使用シナリオについて話しましょう

青灯夜游
青灯夜游転載
2022-02-01 08:00:343052ブラウズ

カスタム コンポーネントで v-model を使用するにはどうすればよいですか? .sync 修飾子はどのようなシナリオで使用されますか?次の記事では、カスタムコンポーネントでの v-model の使用方法と .sync モディファイアの使用シナリオを紹介します。

カスタムコンポーネントでv-modelを使用するにはどうすればよいですか? .sync 修飾子の使用シナリオについて話しましょう

[関連する推奨事項: vue.js ビデオ チュートリアル ]

カスタム コンポーネントで v を使用する方法-モデル?

回答:

カスタムコンポーネントでv-modelを使用するにはどうすればよいですか? .sync 修飾子の使用シナリオについて話しましょう

コードは次のように実装されます:

<input :value="value" @input="handleInput" placeholder="edit me" />

  // ...
  props: {
    value: {
      type: String,
      default: &#39;&#39;
    }
  },
  methods: {
    handleInput(e) {
      this.$emit(&#39;input&#39;, e.target.value)
    }
  }
  // ...

Quote :

<v-base-model v-model="baseModelValue" />
// ...
data() {
  return {
    baseModelValue: &#39;&#39;
  }
}
// ...

コンポーネントの v-model はデフォルトで value という名前のプロップと input という名前のイベントを使用することがわかりますが、これはラジオ ボタンのようなものです。 、チェック ボックス、およびその他のタイプの入力コントロールは、value 属性を さまざまな目的に使用する場合があります。

model オプションを使用すると、このような競合を回避できます:

プロップ名とイベント名をカスタマイズします。コードは次のように実装されます:

<input type="checkbox" :checked="checked" @change="handleChange" />

  // ...
  model: {
    prop: &#39;checked&#39;,
    event: &#39;change&#39;
  },
  props: {
    checked: Boolean
  },
  methods: {
    handleChange(e) {
      this.$emit(&#39;change&#39;, e.target.checked)
    }
  }
  // ...

参照場所:

<v-base-checkbox v-model="baseCheckboxValue" />

data() {
  return {
    baseCheckboxValue: false
  }
}

ここのbaseCheckboxValueの値は、checkedという名前のプロップに渡されます。同時に、<v-base-checkbox></v-base-checkbox> が新しい値で change イベントをトリガーすると、baseCheckboxValue の値が更新されます。

⚠️ コンポーネントの props オプションでこのプロパティを checked 宣言する必要があることに注意してください。

正直なところ、日常の開発では v-model を直接書きたくないのですが、v-model を書かないほうがコードが理解しやすくなります。イベントやイベントが一目瞭然で、一方向のデータフローの特性にも適合しています。

しかし、v-model を使用すると、確かにコードがはるかに単純になります。長所と短所があり、すべては選択次第です。

.sync 修飾子はどのようなシナリオで使用されますか?

回答: 親コンポーネントと子コンポーネントは対話し、親コンポーネントは prop 値を子コンポーネントに渡し、子コンポーネントはイベントをスローして親コンポーネントに変更を通知します。バインディング値。.sync 修飾子の省略形を使用できます。

私が .sync 修飾子に初めて触れたのは、element-ui のダイアログ コンポーネントを使用していたときに、可視属性にそのようなゴーストが表示されたときでした。

カスタムコンポーネントでv-modelを使用するにはどうすればよいですか? .sync 修飾子の使用シナリオについて話しましょう

カスタムコンポーネントでv-modelを使用するにはどうすればよいですか? .sync 修飾子の使用シナリオについて話しましょう

ふと思ったのですが、非同期および同期の状況でポップアップ ウィンドウを表示することは可能でしょうか?別の書き方はありますか? .async? 。

その後、vue のドキュメントを見て、自分が若すぎることに気づきました。幸いなことに、理解できないことに遭遇したときは、必ず自分で調べました。同僚に直接質問する必要がある場合は、次のようにします。それはとても恥ずかしいことです、ああ。

それでは、この .sync 修飾子はどのように使用されるのでしょうか?心配しないでください。.sync 修飾子の使用法を理解するには、vue の一方向データ フローから始める必要があります。

記事の中で v-model を使用せずに Vue での双方向バインディングについて話しましょう? では、vue の一方向のデータ フローについて説明しました。

子コンポーネントは、親コンポーネントによって渡された prop 属性を変更できません。推奨されるアプローチは、イベントをスローし、バインドされた値を独自に変更するように親コンポーネントに通知することです。

カウンター関数を使用して vue の一方向のデータ フローを体験します

サブコンポーネント コード:

<template>
  <div class="test-sync">
    <button @click="add">count + 1</button>
    <p>我们是ti {{ count }} 冠军</p>
  </div>
</template>

<script>
export default {
  name: &#39;test-sync&#39;,
  props: {
    count: {
      type: Number,
      default: 0
    }
  },
  methods: {
    add() {
      this.$emit(&#39;update:count&#39;, this.count + 1)
    }
  }
}
</script>

親コンポーネント コード:

<test-sync :count="count" @update:count="handleAdd" />
//...
data() {
  return {
    count: 8
  }
}
//...
methods: {
  handleAdd(val) {
    this.count = val
  }
}

カスタムコンポーネントでv-modelを使用するにはどうすればよいですか? .sync 修飾子の使用シナリオについて話しましょう

ご覧のとおり、子コンポーネントを使用してイベントをスローし、バインドされた値を変更するように親コンポーネントに通知し、子コンポーネントの prop 値の変更を認識します。

プロセス全体は次のとおりです:

カスタムコンポーネントでv-modelを使用するにはどうすればよいですか? .sync 修飾子の使用シナリオについて話しましょう

一方向のデータ フローを記述するこの方法は、vue によって常に推奨されています。 2.3.0 バージョンでは、.sync 修飾子の構文糖が追加されています。

上記のカウンター関数を .sync を使用して書き換えます。

親コンポーネント コード:

<test-sync :count.sync="count" />
//...
data() {
  return {
    count: 8
  }
}
//...

もっと簡単ではありませんか? .sync 修飾子を使用すると、イベントを記述する必要がなくなります

⚠️子コンポーネント 内部発行イベントが発生するときは、イベント名を update:count の形式で記述する必要があります。そうしないと、.sync 関数は有効になりません。

看着名字如此高大上的功能,居然和 v-model 一样,只是一个语法糖,我了解到真相后,只能手动[捂脸哭]。

那么回到 element-ui dialog 弹窗的 visible 属性,该怎么去用 .sync 属性呢?

很显然,也只是语法糖而已,使用 .sync 修饰符的话,可以少写一点代码。

<el-dialog :visible="dialogVisible" @close="dialogVisible = false">

等价于

<el-dialog :visible.sync="dialogVisible">

⚠️ 注意,不写 .sync 修饰符的话,一定要手动地去调用 close 方法,然后把 dialogVisible 置为 false,不然即使点击关闭按钮也无法关闭弹窗。

为了验证我们的想法,直接去查看 element-ui 的源码

カスタムコンポーネントでv-modelを使用するにはどうすればよいですか? .sync 修飾子の使用シナリオについて話しましょう

果然在 dialog 组件源码的 178 行中发现了我们想要的代码:

this.$emit(&#39;update:visible&#39;, false);

总结

在之前的文章《聊聊Vue中如果不通过v-model实现双向绑定?》 中,我们聊到了 vue 的单向数据流。

这一讲,我们继续聊 v-model 和 .sync 修饰符,结果还是重点讲了 vue 的单向数据流

可见,vue 的单向数据流思想有多么重要,它几乎影响到了你日常开发中的所有组件的设计。

早年的我啥也不懂,直接上手写页面,导致测试的时候,各种 bug 层出不穷,究其根本,就是没有理解 vue 单向数据流的思想,设计的组件数据流转出了问题,还越陷越深,为了解 bug 写出更多 bug。

以后再有人问你 v-model 和 .sync 修饰符相关的问题,咱啥也不管,先把 vue 的单向数据流讲一遍。

希望我的 vue 系列文章能帮助到前端路上的你。

更多编程相关知识,请访问:编程入门!!

以上がカスタムコンポーネントでv-modelを使用するにはどうすればよいですか? .sync 修飾子の使用シナリオについて話しましょうの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はjuejin.cnで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。