通过实例讲解vue组件之间的传值

目录
  • 前言
  • 1.父组件向子组件进行传值
  • 2.子组件向父组件进行传值
  • 3.非父子组件之间的传值
  • 总结

前言

目前在做vue的项目,用到了子组件依赖其父组件的数据,进行子组件的相关请求和页面数据展示,父组件渲染需要子组件通知更新父组件的state,父子组件之间的传值一般有三种方法:

  • 父传子
  • 子传父
  • 非父子传值

注意:

父子组件的关系可以总结为 prop 向下传递,事件向上传递。父组件通过 prop 给子组件下发数据,子组件通过事件给父组件发送消息。

接下来,我们会通过实例代码来看的更清晰,理解更容易:

1.父组件向子组件进行传值

父组件代码:

<template>
  <div>
    父组件:
    <el-input v-model="val" style="width:300px" />
    <child :value="val" />
  </div>
</template>

  <script>
  import child from './child.vue'

  export default {
    name: 'Parent',
    data() {
      return {
        val: '我是父组件'
      }
    },
    components: {
      child
    },

  }
  </script>

子组件代码:

<template>

    <div class="child">
        子组件: {{  value  }}
    </div>

</template>

  <script>

export default {
    name: 'App',
    data() {
        return {
        }
    },
    props: ['value']

}
</script>
  <style scoped>
  .child {
      margin-top: 20px;
  }
  </style>
  

2.子组件向父组件进行传值

父组件代码

<template>
  <div>
    父组件:
    <el-input v-model="val" style="width:300px" />
    <child :value="val" @bindMsg='msgFun' />
  </div>
</template>

  <script>
  import child from './child.vue'

  export default {
    name: 'Parent',
    data() {
      return {
        val: '我是父组件'
      }
    },
    components: {
      child
    },
    methods: {
      msgFun(childVal) {
        console.log(childVal,'childVal')
        this.val = childVal
      }
    }

  }
  </script>

子组件代码

<template>
    <div class="child">
        子组件: {{  value  }}
        <el-button @click="$emit('bindMsg', '我是子组件')">点击改变父组建数据</el-button>
    </div>
</template>

  <script>
export default {
    name: 'App',
    data() {
        return {
        }
    },
    props: ['value'],
}
</script>
  <style scoped>
  .child {
      margin-top: 20px;
  }
  </style>
  

3.非父子组件之间的传值

.sync可以帮我们实现父组件向子组件传递的数据的双向绑定,所以子组件接收到数据后可以直接修改,并且会同时修改父组件的数据

ref绑定在子组件上,引用的指向就是子组件的实例,父组件可以通过 ref 主动获取子组件的属性或者调用子组件的方法

父组件代码

<template>
  <div>
    父组件:
    <el-input v-model="val" style="width:300px" />
    <el-button @click="childRefClick">父组件ref点击</el-button>
    <child :value="val" @bindMsg='msgFun' :data.sync='data' ref='child' />

  </div>
</template>

  <script>
  import child from './child.vue'

  export default {
    name: 'Parent',
    data() {
      return {
        val: '我是父组件',
        data: ''
      }
    },
    components: {
      child
    },
    methods: {
      msgFun(childVal) {
        console.log(childVal, 'childVal')
        this.val = childVal;

      },
      childRefClick() {
        //ref获取子组件实例的属性和方法
        const child = this.$refs.child
        console.log(child.name)

        child.childBtnClick("调用了子组件的方法")
      }
    }
  }
  </script>

子组件代码

<template>

    <div class="child">
        子组件: {{  value  }}
        <el-button @click="childBtnClick">点击改变父组建数据</el-button>
    </div>

</template>

  <script>

export default {
    name: 'App',
    data() {
        return {
            currenData: {}
        }
    },
    props: ['value', 'data'],

    methods: {
        childBtnClick(val) {
            console.log(val,'val')
            this.$emit('bindMsg', val || '我是子组件')
        },

    },
}
</script>
  <style scoped>
  .child {
      margin-top: 20px;
  }
  </style>
  

非父子组件之间的传值方式还有slot插槽,vuex数据状态管理器等等

总结

主要用到了父子组件的传值,props,$emit,ref,sync等方法,父子组件之间的传值,十分常见,只要我们用会了组件之间的传数据的方法,对于前端的组件抽离,性能提升都有很大的好处。

到此这篇关于vue组件之间的传值的文章就介绍到这了,更多相关vue组件间传值内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Vue父子模版传值及组件传值的三种方法

    这里是针对于vue1.0,如果要学2.0,建议大家去看官方文档 vue2.0 http://vuefe.cn/guide/ vue-router2.0https://router.vuejs.org/zh-cn/essentials/getting-started.html 第一种 <div id="example"> <my-component></my-component> </div> <script src="..

  • vue3 父子组件传值详解

    现在距离vue3的诞生已经过了很长时间了,笔者也是近期才开始学习vue3.对比vue2来看,vue3在写法发生了不小的变化,最典型的例子就是vue3通过ref,或者reactive实现数据的响应式.因为ref和reactive的出现,使得vue3中父子组件的传值方式也发生了变化 咱们先看下vue2中的写法 父组件: <!-- 父组件 --> <template> <div> <children :title="title" @getChildr

  • 浅谈Vue父子组件和非父子组件传值问题

    本文介绍了浅谈Vue父子组件和非父子组件传值问题,分享给大家,具体如下: 1.如何创建组件 1.新建一个组件,如:在goods文件夹下新建goodsList.vue <template> <div class='tmpl'> goodsList组件 </div> </template> <style> </style> <script> export default { data() { return{} }, creat

  • Vue实现的父组件向子组件传值功能示例

    本文实例讲述了Vue实现的父组件向子组件传值功能.分享给大家供大家参考,具体如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Vue 父组件向子组件传值</title> <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></scrip

  • 深入理解Vue 组件之间传值

    一.父组件向子组件传递数据 在 Vue 中,可以使用props向子组件传递数据. 子组件部分: 这是 header.vue 的 HTML 部分,logo 是在 data 中定义的变量. 如果需要从父组件获取 logo 的值,就需要使用props: ['logo'] 在 props 中添加了元素之后,就不需要在 data 中再添加变量了 父组件部分: 在调用组件的时候,使用 v-bind 将 logo 的值绑定为 App.vue 中定义的变量 logoMsg 然后就能将App.vue中 logoM

  • Vue父子组件双向绑定传值的实现方法

    父子组件之间的双向绑定非常简单,但是很多人因为是从Vue 2+开始使用的,可能不知道如何双向绑定,当然最简单的双向绑定(单文件中)就是表单元素的 v-model 了,例如 <input type="text" /> 它会响应表单元素的 value 属性,当输入框文本改变时,会将 value 值传给 v-model 所绑定的变量,如果同时设置 v-model 和 value , value 属性无效. 父子组件的自定义双向 v-model 当若干dom封装成组件时,在父组件中

  • vue 组件间的通信之子组件向父组件传值的方式

    父组件向子组件传值:父组件通过属性向下传值的方式和子组件通信: 使用步骤: 定义组件:现有自定义组件com-a.com-b,com-a是com-b的父组件: 准备获取数据:com-b要获取父组件data中的name属性: 在<com-b :name="name"></com-b> 使用v-bind 绑定name属性,红色部分为属性名称,可以随意写. 在子组件定义部分里添加选项,值是个字符串数组 props:['name'],将上边红色的属性名称写在这里: 之后就

  • 详解vue父子组件间传值(props)

    先定义一个子组件,在组件中注册props <template> <div> <div>{{message}}(子组件)</div> </div> </template> <script> export default { props: { message: String //定义传值的类型<br> } } </script> <style> </style> 在父组件中,引入

  • Vue.js中兄弟组件之间互相传值实例

    兄弟组件之间互相传值,需要建立一个"中转站"(新的vue实例),并且需要主动触发. 实例上的$on方法来接受监听. <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>组件传值</title> <script src="vue.js"></script

  • vue 子组件向父组件传值方法

    子组件注册触发事件,父组件注册 触发子组件事件后的方法写在method里面 父组件这么写 <component-a v-on:child-say="listenToMyBoy"></component-a> <p>Do you like me? {{childWords}}</p> methods: { listenToMyBoy: function (somedata){ this.childWords = somedata } } 子

随机推荐