Axios 响应后 scrollTop 不起作用

scrollTop does not work after Axios response

我在使用 Laravel(使用 Vue.js、Pusher、Echo)建立实时聊天时遇到问题。 这里我有3种方法:

created() {
    this.fetchMessages();
    this.group = $('#group').data('group');
    Echo.private('chat.' + this.group)
        .listen('MessageSent', (e) => {
            this.messages.push({
                text: e.message.text,
                user: e.user,
                author: e.user.name,
                avatar: e.message.avatar
            });
        });
},

methods: {
    fetchMessages() {
        axios.get('/chat/check/' + this.group).then(response => {
            this.messages = response.data;

        });
    },

    addMessage(message) {
        axios.post('/chat/add', message).then(response => {
            this.messages.push(response.data);
        });

    }
}`

使用这些方法后,我需要将 <div id="chat"> 滚动到底部。我尝试了很多选项,例如: document.getElementById('chat').scrollTop=9999

同样使用 jQuery $('#chat')...,

一些插件如 vue-scroll-chat 和 jQuery 相同,但其中 none 有效。此命令在方法 fetchMessagesaddMessage 中不起作用 和...

addMessage(message) {
        axios.post('/chat/add', message).then(response => {
            this.messages.push(response.data);
            document.getElementById('chat').scrollTop=9999;
        });
    }

不起作用。我该如何解决?

我认为您需要将 document.getElementById('chat').scrollTop=9999; 添加到 Vue.$nextTick 以便信息有时间出现并在启动滚动效果之前影响元素。

您可能还想添加一个 ref="chat" 到您的聊天元素,以便您可以通过 vue 引用引用 scrollTop;它看起来像这样

addMessage(message) {
    axios.post('/chat/add', message).then(response => {
        this.messages.push(response.data)
        this.$nextTick(
            () => {
                this.$refs.chat.scrollTop=9999;
            }
        )
    })
}