要製做一個在線聊天的程序,在作最後的修飾時,須要對得到的信息即時滾動以保證用戶總能看到最新消息。javascript
聊天程序是基於AJAX設計的,沒有用框架,消息容器是一個DIV,因此問題就在於如何控制DIV的滾動條。html
網上有資料介紹說經過設置scrollTop屬性來控制滾動條位置,具體可參見:
http://hi.baidu.com/chen1345789/blog/item/de727bfb45587b176d22eba1.htmljava
但一樣的代碼拿到我這裏卻徹底失效,又仔細查了下資料說XHTML標準下scrollTop的值恆爲0,解決辦法是使用document.documentElement.scrollTop代替document.body.scrollTop,講了半天所解決的是整個頁面的滾動條。這個方法我是用不了了,由於不是框架結構,因此不可能用body的滾動條控制瀏覽信息。框架
網上關於這個問題的資料不多,連CSDN上也說沒有辦法。ui
不死心,後來查DHTML手冊得知DIV有個doScroll方法能夠用來模擬滾動條點擊,但很使人失望,到了我這裏又是徹底失效,難道又不被XHTML支持?spa
最後終於被我找到三種控制DIV內容滾動的方法:
方法一:
使用錨標記要滾動到的位置,而後經過click方法模擬點擊滾動到錨所在位置
<script language="javascript1.2" type="text/javascript">
function onGetMessage(context)
{
msg.innerHTML+=context;
msg_end.click();
}
</script>
<div style="width:500px;overflow:auto">
<div id="msg" style="overflow:hidden;width:480px;"></div>
<div><a id="msg_end" name="1" href="#1"> </a></div>
</div>設計
方法二:
利用DIV的scrollIntoView方法,將最底端滾動到可視位置 [list=1]<script
language="javascript1.2"
type="text/javascript">
function onGetMessage(context)
{
msg.innerHTML+=context;
msg_end.scrollIntoView();
}
</script>
<div style="width:500px;overflow:auto">
<div id="msg" style="overflow:hidden;width:480px;"></div>
<div id="msg_end" style="height:0px; overflow:hidden"></div>
</div>orm
方法三:xml
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<meta name="keywords" content="滾動條, scrollbar, 頁面底部, 聊天窗口, " />
<meta name="description" content="有些時候(如開發聊天程序),咱們須要將將滾動條(scrollbar)保持在最底部,好比聊天窗口,最新發出和收到的信息要顯示在最下方,若是要看到最下方的內容,就必須保證滾動條保持在最底部。" />
<title>將滾動條(scrollbar)保持在最底部的方法 - 滾動條, scrollbar, 頁面底部, 聊天窗口, </title>
</head>
<body>
<div id="example">
<h3 id="example_title">將滾動條(scrollbar)保持在最底部的方法</h3>
<div id="example_main">
<!--************************************* 實例代碼開始 *************************************-->
<script type="text/javascript">
function add()
{
var now = new Date();
var div = document.getElementById('scrolldIV');
div.innerHTML = div.innerHTML + 'time_' + now.getTime() + '<br />';
div.scrollTop = div.scrollHeight;
}
</script>
<span class="notice">請點擊「插入一行」按鈕,插入最新信息,當出現滾動條時,滾動條將自動保持在底部。</span><br />htm
<div id="scrolldIV" style="overflow:auto; height: 100px; width: 400px; border: 1px solid #999;">
</div>
<input type="button" value="插入一行" onclick="add();">
<!--************************************* 實例代碼結束 *************************************-->
</div>
</div>
</body>
</html>
方法4:
這個比較複雜也比較靈活一點,就是利用DIV+JS+圖片構造一個滾動條,固然了圖片是怎麼好看怎麼用了。
主要部分就是外層的DIV加個overflow:hidden屬性,經過js代碼調整內層DIV的margin-left和margin-top來控制內容的滾動,因爲上面兩種方法已經能夠知足需求,因此這種方法沒具體作深究,有興趣的能夠試一下