消息订阅与发布+$nextTick

本文详细介绍了Vue.js中组件间的通信方式之一——pubsub模式,包括安装、引入、订阅和发布数据的步骤,并展示了在School和Student组件中的应用。同时,文章还探讨了$nextTick的用法,用于在下一轮DOM更新之后执行回调,确保在输入框失去焦点后能够正确聚焦。通过实例展示了如何在组件中使用$nextTick来实现输入框的焦点切换。
摘要由CSDN通过智能技术生成

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()
                })

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值