gpt4 book ai didi

javascript - Vue.js : Call a child method from the parent component

转载 作者:行者123 更新时间:2023-11-30 14:53:20 24 4
gpt4 key购买 nike

我尝试使用 vuejs 和 vuex 与组件进行通信:

  1. 第一个组件是一个菜单
  2. 第二个组件位于第一个组件内,是一个 hamburgerButton

在当前这种情况下,当我单击 hamburgerButton 时,这个按钮是动画的,菜单也是。使用此代码,在单击按钮后,menu 将使用 vueTransition 和 hamburgerButton 进行动画处理。请注意,我使用 vuex 来管理 menuIsOpen 状态。

我的问题是当我单击菜单项时,我想触发 hamburgerButton 动画。

hamburgerButton动画方法,调用animButtonHandler(),封装在一个@click事件中。实际上我知道为什么它不起作用,但我不知道如何处理此方法以单击父元素(菜单项)。所以我的问题是,如何从父组件访问子组件的方法?或者是否有另一种解决方法来实现这一目标?

父组件 - menu.vue :

<template>
<div class="menu">
<!-- import hamburgerButton component -->
<hamburger-button></hamburger-button>
<transition v-on:enter="enterMenuHandler" v-on:leave="leaveMenuHandler">
<div class="menu_wrapper" v-if="this.$store.state.menuIsOpen">
<ul class="menu_items">
<li class="menu_item" @click="$store.commit('toggleMenu')">
<router-link class="menu_link" to="/">home</router-link>
<router-link class="menu_link" to="/contact">contact</router-link>
</li>
</ul>
</div>
</transition>
</div>
</template>

<script>
import hamburgerButton from "hamburgerButton.vue";

export default {
components: {
'hamburger-button': hamburgerButton,
},
methods: {
enterMenuHandler(el, done){
TweenLite.fromTo(el, 0.5, {
opacity: '0',
},{
opacity: '1',
onComplete: done
});
},
leaveMenuHandler(el, done){
TweenLite.to(el, 0.5, {
opacity: '0',
onComplete: done
});
},
}
}
</script>

子组件:hamburgerButton.vue:

<template>
<div class="hamburgerButton" @click="animButtonHandler()">
<div class="hamburgerButton_inner" ref="hamburgerButtonInner">
<i class="hamburgerButton_icon></i>
</div>
</div>
</template>

<script>
export default {
methods: {
animButtonHandler (){
// toggle the state of menu if button clicked
this.$store.commit('toggleMenu');
const isOpen = this.$store.state.menuIsOpen === true;
// anim the button
TweenLite.to(this.$refs.hamburgerButtonInner, 0.5, {
rotation: isOpen ? "43deg" : '0',
});
},
}
}
</script>

store.js(在 main.js 中导入):

let store = new Vuex.Store({
state : {
menuIsOpen : false,
},
mutations: {
toggleMenu(state) {
state.menuIsOpen = !state.menuIsOpen
}
}
});

最佳答案

我添加了事件总线的基本示例。您现在可以将其与明智的人进行比较并进行更改。

如果发现任何困难,请发表评论。

<!DOCTYPE html>
<html>
<head>
<script src="https://unpkg.com/vue@2.1.10/dist/vue.min.js"></script>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<title>JS Bin</title>
</head>
<body>
<div id="app">
<h2>event bus</h2>
<button @click="callChildAnimateMethod"> Button On Parent Call Child </button>
<childcmp><childcmp />
</div>
<script>
var EventBus = new Vue();

Vue.component('childcmp', {
template: `<div>child demo - {{ message }}</div>`,
data: function() {
return {
message: 'hello'
}
},
mounted: function() {
// listen for event
EventBus.$on('animate', this.animButtonHandler);
},
destroyed: function(){
// remove listener
EventBus.$off('animate', this.animButtonHandler);

},
methods: {
animButtonHandler: function() {
console.log('this is child method');
this.message = 'I am changed.'
}
}
});

new Vue({
el: '#app',
data: function() {
return {

}
},
methods: {
callChildAnimateMethod: function() {
EventBus.$emit('animate');
}
}

});
</script>
</body>
</html>

更新


你需要定义EventBus

eventbus.js

import Vue from 'vue';
const EventBus = new Vue();
export default EventBus;

parent component - menu.vue

import EventBus from './eventbus.js'
... your code

child component : hamburgerButton.vue :

import EventBus from './eventbus.js'
... your code

现在 EventBus 将可用于您的代码。

关于javascript - Vue.js : Call a child method from the parent component,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47788396/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com