消息订阅与发布+$nextTick

1、消息订阅与发布pubsub

1. 一种组件间通信的方式,适用于任意组件间通信。

2.使用步骤:

        1.安装pubsub: npm i pubsub-js

        2.引入: import pubsub from 'pubsub-js'

        3.接收数据: A组件想接收数据,则在A组件中订阅消息,订阅的回调留在A组件自身。

methods:{

    demo(data)
    .......

}

    ....

mounted() {

    this.pid = pubsub. subscribe('xxx',this.demo) //订阅消息

}

4.提供数据: pubsub.publish('xxx',数据)

5.最好在beforeDestroy钩子中,用pubsub.unsubscribe(pid)去取消订阅。

School组件

mounted() {
            // console.log('School',this)
            /* this.$bus.$on('hello',(data)=>{
                console.log('我是School组件,收到了数据',data);
            }) */
            this.pubId = pubsub.subscribe('hello',(msgName,data)=>{
                console.log(this);
                // console.log('有人发布了hello消息,hello消息的回调执行了',msgName,data);
            })
        },
beforeDestroy() {
     // this.$bus.$off('hello')
     pubsub.unsubscribe(this.pubId)
},

Student组件

methods:{
     sendStudentName(){
         // this.$bus.$emit('hello',this.name)
         pubsub.publish('hello',666)
           
}

2、$nextTick

下一轮获取焦点

<input type="text" 
                :value="todo.title" 
                v-show="todo.isEdit" 
                @blur="handleBlur(todo,$event)" 
                ref="inputTitle"
            >
this.$nextTick(function(){
                    this.$refs.inputTitle.focus()
                })

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值