经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » Vue.js » 查看文章
vue.js父子组件传参的原理与实现方法[原创]
来源:jb51  时间:2023/4/26 8:49:52  对本文有异议

在Vue中,父子组件之间的数据传递常常会使用props进行实现。具体原理是,当一个父组件嵌套了一个子组件时,在子组件内部使用props接收从父组件传递过来的数据,这些数据可以是基础类型如字符串、数字等,也可以是对象或者数组等复杂类型。

下面展示一个例子,通过一个简单的计数器组件Counter.vue,演示如何在父组件App.vue中传值到子组件Counter.vue并更新计数器操作:

子组件:

  1. <!-- Counter.vue -->
  2. <template>
  3. ? <div class="counter">
  4. ? ? <h4>{{ title }}</h4>
  5. ? ? <p>当前计数:{{ count }}</p>
  6. ? ? <button @click="addCount">+1</button>
  7. ? ? <button @click="reduceCount">-1</button>
  8. ? </div>
  9. </template>
  10.  
  11. <script>
  12. export default {
  13. ? name: "Counter",
  14. ? props: {
  15. ? ? title: {
  16. ? ? ? type: String,
  17. ? ? ? required: true,
  18. ? ? },
  19. ? ? count: {
  20. ? ? ? type: Number,
  21. ? ? ? required: true,
  22. ? ? },
  23. ? },
  24. ? methods: {
  25. ? ? // 添加计数
  26. ? ? addCount() {
  27. ? ? ? this.$emit("add-count");
  28. ? ? },
  29. ? ? // 减少计数
  30. ? ? reduceCount() {
  31. ? ? ? this.$emit("reduce-count");
  32. ? ? },
  33. ? },
  34. };
  35. </script>

父组件:

  1. <!-- App.vue -->
  2. <template>
  3. ? <div class="container">
  4. ? ? <h2>计数器应用</h2>
  5. ? ? <hr />
  6. ? ? <!-- 父组件传递计数器标题和当前计数给子组件 -->
  7. ? ? <Counter :title="title" :count="count" @add-count="handleAddCount" @reduce-count="handleReduceCount" />
  8. ? </div>
  9. </template>
  10.  
  11. <script>
  12. import Counter from "./components/Counter.vue";
  13.  
  14. export default {
  15. ? name: "App",
  16. ? components: {
  17. ? ? Counter,
  18. ? },
  19. ? data() {
  20. ? ? return {
  21. ? ? ? title: "计数器",
  22. ? ? ? count: 0,
  23. ? ? };
  24. ? },
  25. ? methods: {
  26. ? ? // 添加计数
  27. ? ? handleAddCount() {
  28. ? ? ? this.count++;
  29. ? ? },
  30. ? ? // 减少计数
  31. ? ? handleReduceCount() {
  32. ? ? ? this.count--;
  33. ? ? },
  34. ? },
  35. };
  36. </script>

在上述示例中,传递数据的方式是通过在父组件中使用v-bind指令将数据绑定到子组件的props属性上,并在子组件内部访问props接收数据。同时,在子组件内部定义了两个方法addCount和reduceCount,用于触发自定义事件,从而向父组件emit事件。

最后需要注意的是,父子组件之间的数据流是单向的,即数据只能从父组件流向子组件,不能反过来。如果子组件想要修改数据,必须通过emit事件来通知父组件进行相应的操作。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号