ホームページ  >  に質問  >  本文

javascript - vue2.0是不是不能用event bus了

在vue1中可以通过

var bus = new Vue()
// 触发组件 A 中的事件
bus.$emit('id-selected', 1)
// 在组件 B 创建的钩子中监听事件
bus.$on('id-selected', function (id) {
  // ...
})

进行不同组件之间的通信,在vue2.0中我试了下这个方法,没有实现,是不是已经被废弃了,那该用什么来代替呢?

天蓬老师天蓬老师2771日前373

全員に返信(5)返信します

  • 巴扎黑

    巴扎黑2017-04-11 11:02:09

    並沒有被廢棄,還是存在著,語法一樣是

    const Bus = new Bus();
    
    Bus.$on('greeting', (msg) => console.log('哈囉, ' + msg);
    Bus.$emit('greeting', 'Something');
    

    如果你輸入的代碼如同上面那個...那應該是順序問題,因為你是放在鉤子裡:
    我簡單的在父組件與子組件的鉤子裡 console.log,你可以看到他們的執行順序,這或許就是沒正確執行的原因,必須保證先 $on$emit

    例子

    返事
    0
  • 迷茫

    迷茫2017-04-11 11:02:09

    谢邀,但是我不会 vueJs....汗!

    返事
    0
  • 阿神

    阿神2017-04-11 11:02:09

    这样写

    <component_b @selected="fun"></component_b>

    返事
    0
  • PHP中文网

    PHP中文网2017-04-11 11:02:09

    $emit/$on 在 2.0 中是可以使用的。

    $dispatch 和 $broadcast 弃用

    返事
    0
  • 伊谢尔伦

    伊谢尔伦2017-04-11 11:02:09

    https://github.com/yangmingsh...

    返事
    0
  • キャンセル返事