javascript - axios响应后scrollTop不起作用

标签 javascript jquery laravel vue.js axios

我在使用 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 也是如此,但它们都不起作用。此命令在方法 fetchMessages 中不起作用和addMessage 还有...

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

关于javascript - axios响应后scrollTop不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47478772/

相关文章:

javascript - 获取asp :checkbox inside a datalist using jquery的id

javascript - 将属性添加到 jQuery 中的 &lt;input&gt; 每个循环仅在第一次通过时?

laravel - 升级到 Laravel 5.3 - 路由未定义错误

php - Laravel 6 验证 : there is limit in number of rules?

javascript - 安卓 WebView "Uncaught SyntaxError: Unexpected token ILLEGAL"

javascript - 从 flickr api/YQL 中提取城镇/城市

javascript - 如何为内容和左侧菜单设置单独滚动

javascript - 如何在回调函数中为 chrome 扩展图标设置动画?

laravel - 多个 id 的 UpdateExistingPivot

javascript - 未捕获的类型错误 : Cannot read property 'style' of null concerning a script in an echo