javascript - 除非用户更改滚动条的位置,否则将滚动条保持在底部

标签 javascript html css

前几天我asked当新数据进来时,我怎样才能将滚动条保持在底部。我得到了this answer这对我来说非常好。但是现在我有一个新的要求。我希望滚动条停留在我使用它的位置。例如,当页面加载时,如果我不触摸滚动条,那么滚动条应该保持在底部。但是如果我触摸它并把它拿起来,那么它应该会留在那儿,不会自动掉下来。

这是我的代码:

<style>
#conversationDiv {
height: 900px;
overflow: auto;     
} 
</style>

<script>
$(function () {
  setInterval(function() {
    var element = document.getElementById("conversationDiv");
    element.scrollTop = element.scrollHeight;
  }, 0);
});
</script>


<div id="conversationDiv">

编辑:我在下面发布了完整的代码,其中显示了消息的来源以及它们附加到哪个 div 的位置。

<!DOCTYPE html>
<html>
<head>
<title>Hello WebSocket</title>
<script
src="https://cdnjs.cloudflare.com/ajax/libs/sockjs-client/1.1.0/sockjs.js">   </script>
<script
src="https://cdnjs.cloudflare.com/ajax/libs/stomp.js/2.3.3/stomp.js"></script>
<script src="https://code.jquery.com/jquery-2.1.4.js"></script>
<style>
#conversationDiv {
height: 900px;
}
</style>
<script>
 $(function () {     
  setInterval(function() {       
   var element = document.getElementById("conversationDiv");
    element.scrollTop = element.scrollHeight;
   }, 0);
});  
</script>
<script type="text/javascript">
    var stompClient = null;
    function setConnected(connected) {
        document.getElementById('connect').disabled = connected;
        document.getElementById('disconnect').disabled = !connected;
        document.getElementById('conversationDiv').style.visibility = connected ? 'visible' : 'hidden';
        document.getElementById('response').innerHTML = '';
    }

    function connect() {
        var socket = new SockJS("http://twitchbot-farazdurrani.rhcloud.com:8000/hello/");
        stompClient = Stomp.over(socket);
        stompClient.connect({}, function(frame) {
            setConnected(true);
            console.log('Connected: ' + frame);
            stompClient.subscribe("/topic/greetings", function(greeting){
                showGreeting(greeting.body);
            });
        });
    }

    function disconnect() {
        if (stompClient != null) {
            stompClient.disconnect();
        }
        setConnected(false);
        console.log("Disconnected");
    }

    function sendName() { //I am not sending anything so remove this..
        var name = document.getElementById('name').value;
        stompClient.send("/app/hello", {}, JSON.stringify({ 'name': name     }));
    } 

    function showGreeting(message) {
        var response = document.getElementById('response');
        var p = document.createElement('p');
        p.style.wordWrap = 'break-word';
        p.appendChild(document.createTextNode(message));
        response.appendChild(p);
    }        
</script>
</head>
<body onload="connect()">
<div>
    <div>
        <button id="connect" onclick="connect();">Connect</button>
        <button id="disconnect" disabled="disabled" onclick="disconnect();">Disconnect</button>
    </div>
    <div id="conversationDiv" style="overflow:auto">            
        <p id="response"></p>
    </div>
</div>

有关正在发生的事情的一些信息:这是一个单向聊天系统(使用 WebSockets),其中只有一方发送消息。那是服务器端。所有的魔法都发生在 function showGreeting(message) {..} 中,它正在创建元素和附加子元素等。我希望这能帮上点忙。 谢谢

最佳答案

为此你可能需要一个标志。所以我正在做的是:

  1. 当触发滚动事件时(即使在追加时也会触发),我们需要检查滚动的部分是否在末尾。
  2. 如果还没有结束,我们需要清除间隔。
  3. 如果结束,重新初始化间隔。

不确定为什么它不起作用。我有我在这里工作的脚本。

$(function () {
  var count = 1;
  setInterval(function () {
    $("#conversationDiv").append('<p>Message #' + count++ + ': Lorem ipsum dolor sit amet, consectetur adipisicing elit. Praesentium repudiandae doloribus unde, repellat maiores minus fuga earum esse, ab, aperiam voluptatibus est dolorem placeat perferendis omnis libero dolore alias quasi!</p>');
  }, 1000);
  var scr = setInterval(function() {
    var element = document.getElementById("conversationDiv");
    element.scrollTop = element.scrollHeight;
  }, 500);
  $("#conversationDiv").scroll(function () {
    var element = document.getElementById("conversationDiv");
    if ((Number(element.scrollTop) + Number($(element).height())) != (Number(element.scrollHeight)))
      clearInterval(scr);
    else
      if (element.scrollTop < element.scrollHeight)
      scr = setInterval(function() {
        var element = document.getElementById("conversationDiv");
        element.scrollTop = element.scrollHeight;
      }, 500);
  });
});
* {font-family: 'Segoe UI'; margin: 0; padding: 0; list-style: none;}

#conversationDiv {height: 350px; overflow: auto; border: 1px solid #ccc;}
#conversationDiv p {margin: 5px 5px 10px; padding: 5px; border: 1px solid #ccc; background-color: #f5f5f5;}
<script src="https://code.jquery.com/jquery-2.1.4.js"></script>
<div id="conversationDiv">
  
</div>

好像少了什么。我快接近它了。 Number(element.scrollTop), Number($(element).height()), Number(element.scrollHeight) 区域应该有东西吗

关于javascript - 除非用户更改滚动条的位置,否则将滚动条保持在底部,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37995579/

相关文章:

javascript - 使用 D3 选择 none 是否有用,如何使用?

javascript - Superzised with bootstrap - 2列响应式布局

横幅图片的 JavaScript 递归函数

javascript - 使用 jquery 提交一个在不同选项卡上包含多个不同字段的表单。

jquery - 输入不保持焦点

javascript - 是否有用于上下文感知弹出窗口的 JavaScript 框架?

jquery - 使用 jquery 平滑过渡到 div 排序

css - 如何使底层div不可点击?

jquery - 恢复未设置的 div 宽度

javascript - 菜单项 - onclick FadeInDown 和 FadeOutUp