javascript - vue中的自定义事件只能子传父?
PHPz
PHPz 2017-04-10 17:29:25
[JavaScript讨论组]

我想通过父组件中的this.$emit的方法来触发子组件中的this.$on,应该要怎么做?
我做过的尝试:
使用vue2.x

style:

#parent {
        width: 200px;
        height: 200px;
        background-color: #eee;
    }
    
.child {
    width: 100px;
    height: 100px;
    background-color: red;
}

html:

{{ total }}

javascript:

Vue.component('child', {
    template: '

{{ counter }}

', created: function() { //子组件初始化时监听'increment'事件 this.$on('increment', function() { this.counter += 1; }); }, data: function() { return { counter: 0 } }, methods: { add: function() { //子组件中点击后执行,触发自身increment事件 this.$emit('increment'); } }, }) new Vue({ el: '#parent', data: { total: 0 }, methods: { test: function() { //父组件中点击后执行,不触发子组件的increment事件 this.total += 1; this.$emit('increment'); } } })
PHPz
PHPz

学习是最好的投资!

全部回复(2)
迷茫

确实无法使用父组件触发子组件的事件,但是可以使用props代替。
在子组件监听传值,传值改变则触发事件。

天蓬老师

组件是为了解耦。也就是说,父组件中可能没有子组件,这个时候怎么传。
不过,可以采用其他方式实现:比如通过props来通知子组件,父组件的变化。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号