Vue2之父与子组件互相传参和方法调用

简介: 这篇文章介绍了Vue 2中父子组件之间互相传参和方法调用的四种方式:通过`ref`调用子组件方法、通过`props`调用父组件方法、父组件通过`:param`传参给子组件,以及子组件通过`emit`传参给父组件。

1、父组件通过ref调用子组件方法

父组件【index.vue】
<SearchTool ref="searchToolRef"/>

methods: {
   
    // ...

    /**
     * 刷新任务数据
     */
    reflashTaskTable() {
   
        // 父组件调用子组件【searchTool.vue】的onSubmit方法
        this.$refs['searchToolRef'].onSubmit()
    }
}

子组件【searchTool.vue】,别名为【searchToolRef】
methods: {
   
    // ...

    /**
     * 提交搜索框的表单数据,执行查询
     */
    onSubmit() {
   
        // ...
    }
}

2、子组件通过props调用父组件方法

父组件【index.vue】
<SearchTool :reflashTaskTable="reflashTaskTable"/>

methods: {
   
    // ...

    /**
     * 刷新任务数据
     */
    reflashTaskTable() {
   
        // ...
    },
}


子组件【searchTool.vue】,别名为【searchToolRef】
props: ["reflashTaskTable"]

methods: {
   
    // ...

    /**
     * 刷新任务数据句柄
     */
    handleReflashTaskTable() {
   
        // ...
        this.reflashTaskTable();
    },
}

3、父组件通过:param传参给子组件

父组件【index.vue】
 <SearchTool :levelList="levelList"/>

 data: () => ({
   
    levelList: ['Lv1', 'Lv2', 'Lv3', 'Lv4', 'Lv5']
 })

子组件【searchTool.vue】,别名为【searchToolRef】
props: ["levelList"]

watch: {
   
    levelList: function(newVal, oldVal) {
   
        console.log(newVal);
    }
}

4、子组件通过emit传参给父组件

子组件【searchTool.vue】,别名为【searchToolRef】
methods: {
   
    // ...

    /**
     * 删除任务
     */
    deleteTaskByIds() {
   
        // ...
        this.$emit("handleDeleteTaskByIds", "181191");
    }
}

父组件【index.vue】
<SearchTool @handleDeleteTaskByIds="handleDeleteTaskByIds"/>

methods: {
   
    // ...

    /**
     * 删除任务句柄
     */
    handleDeleteTaskByIds(val) {
   
        // ...
        console.log(val);// 181191
    },
}
目录
相关文章
|
6月前
|
前端开发 API
react怎么实现父子组件传值?
react怎么实现父子组件传值?
31 1
|
4月前
|
前端开发 JavaScript 开发者
react18【系列实用教程】组件 (2024最新版 | 含父子组件传值、兄弟组件传值、越层组件传值、“插槽“)
react18【系列实用教程】组件 (2024最新版 | 含父子组件传值、兄弟组件传值、越层组件传值、“插槽“)
66 2
|
6月前
|
JavaScript
vue怎么实现父子组件传值
vue怎么实现父子组件传值
31 0
|
6月前
|
JavaScript
vue通讯 传值 3大传值方法 快速上手 父子间传值和非父子间传值
vue通讯 传值 3大传值方法 快速上手 父子间传值和非父子间传值
|
6月前
|
JavaScript
vue子组件向父组件传参的方式
vue子组件向父组件传参的方式
55 0
|
6月前
|
前端开发
react怎么实现父子组件传值
react怎么实现父子组件传值
|
JavaScript
vue父子组件传参和接收的方法
在Vue中,组件之间传递参数常用的方法有以下几种: 父组件向子组件传递参数
132 0
|
JavaScript
Vue setup语法糖关于父子传参不同之处
Vue setup语法糖关于父子传参不同之处
|
前端开发
react 父子组件传参
react 父子组件传参
|
JavaScript
Vue3自定义封装组件,父子组件传值
Vue3自定义封装组件,父子组件传值