视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
vue父组件怎么调用子组件
2020-11-27 19:52:48 责编:小采
文档
这次给大家带来vue父组件怎么调用子组件,vue父组件调用子组件的注意事项有哪些,下面就是实战案例,一起来看一下。

情景:

  父组件中引入上传附件的子组件:点击组件可以分别上传对应要求的图片,子组件内部循环可创建多个模块.

  父组件传入数组子组件循环来创建不同的组件模块,所有事件都在子组件内部.

  父组件页面的上方同时有一个上传图片按钮上传图片后会显示在第一个模块:

  设想思路:点击父组件中的按钮触发子组件中上传方法:

  子组件上定义ref="refName",父组件的方法中用this.$refs.refName.method去调用子组件方法

  子组件中处理上传的方法:  

 fileClick(index) {
 console.log('子组件的fileClick被调用了')
 console.log('index: '+index)
 // this.aaa();
 if(!this.fileInfor[index].imgUrl){
 //如果当前框里没有图片,则实现上传
 document.getElementsByClassName('upload_file')[index].click();
 } 
},

  父组件template

<template>
 <x-button type="submit" class="custom-primary" @click.native="xiechengUpload">上传图片</x-button>
 <up-load :fileInformation="fileInformation" ref="uploadRef"></up-load>
</template>

  父组件method中定义方法,同时传入相应的index值.

Upload(){
 // console.log('父组件的xiechengUpload被调用了')
 this.$refs.uploadRef.fileClick(0);
},

此时就可以通过上传按钮将图片放到子组件的第一个模块中了.

下面看下Vue父组件调用子组件事件

Vue父组件向子组件传递事件/调用事件

不是传递数据(props)哦,适用于 Vue 2.0

方法一:子组件监听父组件发送的方法

方法二:父组件调用子组件方法

子组件:

export default {
 mounted: function () {
 this.$nextTick(function () {
 this.$on('childMethod', function () {
 console.log('监听成功')
 })
 })
 },
 methods {
 callMethod () {
 console.log('调用成功')
 }
 }
}

父组件:

<child ref="child" @click="click"></child>
export default {
 methods: {
 click () {
 this.$refs.child.$emit('childMethod') // 方法1
 this.$refs.child.callMethod() // 方法2
 },
 components: {
 child: child
 }
}

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

源生JS实现文件拖拽事件

vue全局局部组件使用详解

下载本文
显示全文
专题