vue父子组件的互相传值和调用

 更新时间:2021年04月22日 14:58:15   作者:Louis码农工具人  
这篇文章主要介绍了vue父子组件的互相传值和调用,帮助大家更好的理解和学习使用vue框架,感兴趣的朋友可以了解下

1、父传值给子组件

父组件:

<template>
  <div>
    <p class="father">父组件</p>
    <child :sid="id"></child>
  </div>
</template>

<script>
import child from './child'
export default {
  components: {
    child
  },
  data() {
    return {
      id:'1234' // 父组件向子组件传的值
    }
  }
}
</script>

子组件:

<template>
  <div>
    <p class="child">子组件</p>
    <p class="child">接收父组件的值是:{{ sid }}</p>
  </div>
</template>

<script>
export default {
  props:{
    sid:{
      type:String,
      default: '0'
    }
  },
  // props:["sid"],
  data() {
   return { 

   } 
 } 
} 
</script>

说明:

①sid是在子组件中绑定要传的值,记住“=”前的sid要和子组件中要接受的变量名要一致

②在子组件中用props来接受传入的值,可以写成对象类型,规定类型和默认值,也可以直接写成字符串

③在子组件中可以直接使用,也可以在函数中使用this.sid进行访问

2、子传值给父组件

父组件:

<template>
  <div>
    <p class="father">父组件</p>
    <p class="father">接收到子组件的值:{{childSid}}</p>
    <child @passVaule="parentPassValue"></child>
  </div>
</template>

<script>
import child from './child'
export default {
  components: {
    child
  },
  data() {
    return {
      childSid:'' // 接收子组件的值
    }
  },
  methods: {
    parentPassValue(data) {
      this.childSid = data;
    }
  }
}
</script>

子组件:

<template>
  <div>
    <p class="child">子组件</p>
    <button @click="valueClick">传值</button>
  </div>
</template>

<script>
export default {
  data() {
    return {
    }
  },
  methods: {
    valueClick() {
      this.$emit('passVaule',19)
    }
  }
}
</script>

说明:

①子组件中给一个方法去触发$emit,第一个参数是在父组件引入子组件绑定的函数名('passVaule'),第二个是要传的值(19)

②父组件中绑定一个函数,调用父组件中绑定的函数,在其中对值进行接收操作

3、子调用父组件中的方法

父组件:

<template>
  <div>
    <p class="father">父组件</p>
    <child @funVaule="parentFunValue"></child>
  </div>
</template>

<script>
import child from './child'
export default {
  components: {
    child
  },
  data() {
    return {
    }
  },
  methods: {
    parentFunValue() {
      console.log('调用了父组件中的函数');
    }
  }
}
</script>

子组件:

<template>
  <div>
    <p class="child">子组件</p>
    <button @click="funClick">调用父组件方法</button>
  </div>
</template>

<script>
export default {
  data() {
    return {
    }
  },
  methods: {
    funClick() {
      this.$emit('funVaule')
    }
  }
}
</script>

说明:

①这个和子传值给父类似,只是不传值,调用了父组件的绑定的函数

4、父调用子组件中的方法

父组件:

<template>
  <div>
    <p class="father">父组件</p>
    <button @click="childClick">调用子组件方法</button>
    <child ref="mychild"></child>
  </div>
</template>

<script>
import child from './child'
export default {
  components: {
    child
  },
  data() {
    return {
    }
  },
  methods: {
    childClick() {
      this.$refs.mychild.testNum(1)
    }
  }
}
</script>

子组件:

<template>
  <div>
    <p class="child">子组件</p>
</button>
  </div>
</template>

<script>
export default {
  data() {
    return {
    }
  },
  methods: {
    testNum(data) {
      console.log('调用了子组件中的方法:', data);
    }
  }
}
</script>

说明:

① 父组件中在引入的子组件中写入 ref = "mychild"   mychid为自己定义的实例名

② 在函数中写 this.refs.mychild.testNum(), “testNum”为子组件中定义的函数名

③子组件定义一个函数,让父组件调用即可

④这个方法也可以进行传值,在括号中传入值,子组件接收即可 

以上就是vue父子组件的互相传值和调用的详细内容,更多关于vue父子组件的传值和调用的资料请关注脚本之家其它相关文章!

相关文章

  • vue 解决form表单提交但不跳转页面的问题

    vue 解决form表单提交但不跳转页面的问题

    今天小编就为大家分享一篇vue 解决form表单提交但不跳转页面的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • Vue使用NProgress的操作过程解析

    Vue使用NProgress的操作过程解析

    这篇文章主要介绍了Vue使用NProgress的操作过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • Vue3 Suspense处理异步组件加载的工作原理

    Vue3 Suspense处理异步组件加载的工作原理

    Vue3在新版本中提供了一个新的API,称为Suspense,它可以使异步组件的加载更加高效和流畅,在本文中,我们将详细了解 Vue3 Suspense 处理异步组件加载的工作原理以及如何使用它来提高 Web 应用程序的性能
    2023-06-06
  • Vue实战教程之仿肯德基宅急送App

    Vue实战教程之仿肯德基宅急送App

    这篇文章主要介绍了Vue实战教程之仿肯德基宅急送App,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-07-07
  • VUE使用localstorage和sessionstorage实现登录示例详解

    VUE使用localstorage和sessionstorage实现登录示例详解

    这篇文章主要为大家介绍了VUE使用localstorage和sessionstorage实现登录示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • vue2.0+vue-dplayer实现hls播放的示例

    vue2.0+vue-dplayer实现hls播放的示例

    这篇文章主要介绍了vue2.0+vue-dplayer实现hls播放的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • 解决vue动态路由异步加载import组件,加载不到module的问题

    解决vue动态路由异步加载import组件,加载不到module的问题

    这篇文章主要介绍了解决vue动态路由异步加载import组件,加载不到module的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • Vue实现base64编码图片间的切换功能

    Vue实现base64编码图片间的切换功能

    这篇文章主要介绍了Vue实现base64编码图片间的切换功能,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-12-12
  • 微信小程序Webview与H5通信的思路与实战记录

    微信小程序Webview与H5通信的思路与实战记录

    这篇文章主要介绍了微信小程序Webview与H5通信的思路与实战的相关资料,由于微信小程序与H5之间的通信限制,无法满足业务需求,通过动态改变url的hash值来传递参数,并利用vue-router组件的路由守卫来避免页面刷新,需要的朋友可以参考下
    2025-01-01
  • vue+element下拉列表默认值问题

    vue+element下拉列表默认值问题

    这篇文章主要介绍了vue+element下拉列表默认值问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06

最新评论