javascript設定滾動條高度的方法:首先取得目前選取的li前面的節點的高度;然後減去ul高度的一半設定給ul的scrollTop,把捲軸設定在中間位置即可。
本文操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。
JavaScript動態設定捲軸高度
工作中遇到情形如下:一個ul標籤,裡面有許多li標籤,其中有一個代表初始化已選取的5d7e5b63bb2c2f21c9ee5b2d95d6d3b225edfb22a4f469ecb59f1190150159c6。
如果ul設定了高度,如下面的ul的style,並且有很多li子標籤,那選中的li就被淹沒在滾動條下面。
<ul id="ul_module" style="height:180px; overflow-y:scroll;"> <li>...</li> <li>...</li> <li>...</li> <li>...</li> <li>...</li> <li>...</li> <li>...</li> <li>...</li> <li>...</li> <li>000</li> <li>111</li> <li>222</li> <li>333</li> <li>444</li> <li>555</li> <li>666</li> <li>777</li> <li>888</li> <li class="li-on">999</li> <li>...</li> <li>...</li> <li>...</li> <li>...</li> <li>...</li> <li>...</li> <li>...</li> <li>...</li> <li>...</li> </ul>
要做的就是要把這個選取的li標籤,現在到可見區域內,可以透過js動態的設定捲軸的高度。
具體如下:取得目前選取的li前面的節點的高度,然後減去ul高度的一半設定給ul的scrollTop,基本上可以把捲軸設定在中間位置。
var ul_module = $('#ul_module'); var ul_height = ul_module.height(); var seleted_li = ul_module.find('.li-on'); if(seleted_li.length) { var height = seleted_li.height(); var prevCount = seleted_li.prevAll().length; ul_module.scrollTop(height * prevCount - ul_height/2); }
【推薦學習:javascript進階教學】
以上是javascript怎麼設定滾動條高度的詳細內容。更多資訊請關注PHP中文網其他相關文章!