• 技术文章 >web前端 >js教程

    javascript怎么设置滚动条高度

    藏色散人藏色散人2021-04-19 10:23:29原创1664

    javascript设置滚动条高度的方法:首先获得在当前选中的li前面的节点的高度;然后减去ul高度的一半设置给ul的scrollTop,把滚动条设置在中间位置即可。

    本文操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

    JavaScript动态设置滚动条高度

    工作中遇到情形如下:一个ul标签,里面有很多li标签,其中有一个代表初始化已选中的<li class="li-on"><li>。

    如果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中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:javascript
    上一篇:初步了解Nodejs中的异步I/O 下一篇:如何关掉javascript
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• javascript如何实现图片切换• javascript如何改变背景• javascript如何关闭当前页面• javascript如何调用函数• javascript中$是什么意思
    1/1

    PHP中文网