javascript – 始终显示niceScroll导轨

前端之家收集整理的这篇文章主要介绍了javascript – 始终显示niceScroll导轨前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用 niceScroll jQuery插件来替换溢出的< div>中的常见浏览器滚动条.该插件运行良好,但我不能让它工作并始终显示滚动轨道(即使内容不超过< div>界限).我的最终配置是:
$(document).ready(function () {
    $(".div-wrapper").niceScroll({
        cursorcolor: "#333",cursoropacitymin: 0.3,background: "#bbb",cursorborder: "0",autohidemode: false,cursorminheight: 30
    });
};

我试图触发$(“.div-wrapper”).getNiceScroll().show()但它似乎也没有用.

任何帮助将不胜感激,谢谢

解决方法

首先,你最后有一个缺失的括号 – 这可能是你的问题吗?

将autohidemode设置为false仅表示当用户停止滚动时它不会消失,然后在滚动时再次出现.不幸的是,如果内容没有溢出,这并不意味着它是可见的.

作为一种解决方法,您可以尝试使用以下内容调用.niceScroll()后,明确显示id = ascrail2000的元素:

$(document).ready(function () {
    $(".div-wrapper").niceScroll({
        cursorcolor: "#333",cursorminheight: 30
    });
    $('#ascrail2000').show();
});

在最后一行中看到遗失的部分

您可能还需要使其子元素可见:

$('#ascrail2000 *').show();

(在你的情况下,确保元素的id是ascrail2000.)

更新:正如veritas指出的那样,使用更通用的选择器div [id ^ =’ascrail’]而不是#ascrail2000使得它可以在一个页面上运行多个nicescroll,因此上述操作可以通过JavaScript完成:

$("div[id^='ascrail']").show();

或者在CSS中:

div[id^='ascrail'] { display: block; }

或者如果上述方法不起作用:

div[id^='ascrail'] { display: block !important; }

这不是最优雅的解决方案,但我担心这是解决此问题的唯一方法,因为nicescroll插件没有选择该行为的选项.幸运的是,nicescroll是开源的,available on GitHub因此可以轻松地将它分叉并在GitHub上添加这样的选项或post a feature request.

猜你在找的JavaScript相关文章