利用div+jquery自定义滚动条样式的2种方法

时间:2024-04-19 10:18:13 

最近做项目中有一个模块是用于实时监控的,左边有个菜单栏用于显示所有的设备,那当然是从数据库中动态获取的了,右边是个iframe用于显示监控画面。本来这个功能并不复杂,左边的菜单项是利用dtree.js来实现的,可时当功能实现完成之后,却发现一个问题,就是左边菜单栏中的设备名有的会很长,会超出了div的长度,准确说是左边iframe的宽度和长度不够。那么,这时就必须要利用滚动条了,可以设置左边菜单项div的overflow-x:auto;overlfow-y:auto;这样就会自动生成了滚动条,但是大家都知道自带的不好看。接下来就是重点了,如何修改滚动条的样式呢?

经过从网上的不断搜索,发现有两种方法:

第一种方法:利用CSS提供的样式,一共是8种属 * ,在这里不做详细介绍,网上很多这方面的资料。

第二种方法:自己写一个新的滚动条,即不用div自带的滚动条。这样想要什么样的效果就有什么样的效果。具体实现,在网上搜了很多,可以发现基本上只有竖向滚动条,而没有横向滚动条,无奈之下,自己利用jquery写另一个滚动条,当然也借鉴了只有竖向滚动条的程序。

说一下具体实现思路:目标div 即需要生成滚动条的div,里面嵌套了3个div,分别是用于显示内容的div_content,显示竖向滚动条的div_H,显示横向滚动条的div_W,具体布局就是按照自带滚动条的div的布局一样,然后显示滚动条的div即div_H和div_W有各自包含了3个div,即左右箭头2个,滚动条1个。具体代码如下:


if($(_self).children(".jscroll-c").height()==null){
//添加内容框(div)
$(_self).wrapInner("<div class='jscroll-c' style='top:0px;z-index:9999;zoom:1;position:relative;'></div>");
//添加竖向滚动条
$(_self).append("<div class='jscroll-e' unselectable='on' style='height:97.5%;top:0px;right:0;-moz-user-select:none;position:absolute;overflow:hidden;z-index:10000;'><div class='jscroll-u' style='position:absolute;top:0px;width:100%;right:0;background:blue;overflow:hidden'></div><div class='jscroll-h' unselectable='on' style='background:green;position:absolute;left:0;-moz-user-select:none;border:1px solid'></div><div class='jscroll-d' style='position:absolute;bottom:0px;width:100%;left:0;background:blue;overflow:hidden'></div></div>");
//添加横向滚动条
$(_self).append("<div class='jscroll-s' unselectable='on' style='width:180px;bottom:0px;left:0;-moz-user-select:none;position:absolute;overflow:hidden;z-index:10000;'><div class='jscroll-l' style='position:absolute;bottom:0px;height:100%;left:0;background:blue;overflow:hidden'></div><div class='jscroll-g' unselectable='on' style='height:100%;background:green;position:absolute;left:0;-moz-user-select:none;border:1px solid'></div><div class='jscroll-r' style='position:absolute;bottom:0px;height:100%;right:0;background:blue;overflow:hidden'></div></div>");
}


然后无非就是一些判断,div的内容是否超过了div的范围,监听事件的添加。具体代码可见我的下载资源;

标签:jquery,滚动条
0
投稿

猜你喜欢

  • Mysql如何通过binlog日志恢复数据详解

    2024-01-16 16:53:57
  • Python3读写ini配置文件的示例

    2023-05-29 22:59:21
  • asp 去除最后一个逗号为空字符串的代码

    2010-06-09 19:18:00
  • python图像和办公文档处理总结

    2021-03-08 19:24:02
  • django之导入并执行自定义的函数模块图解

    2023-07-27 02:45:19
  • Python Matplotlib绘制箱线图boxplot()函数详解

    2021-03-09 11:16:07
  • sql 查询本年、本月、本日记录的语句,附SQL日期函数

    2024-01-25 01:00:55
  • Python列表和集合的效率大比拼

    2021-09-04 14:10:16
  • Date对象格式化方法

    2009-11-16 13:17:00
  • javascript修改图片src的方法

    2024-04-17 10:40:29
  • Python 查看文件的编码格式方法

    2021-11-01 10:50:39
  • 对python中return与yield的区别详解

    2022-10-19 00:47:33
  • 运用python去除图片水印

    2021-05-06 10:54:20
  • MySQL百万级数据量分页查询方法及其优化建议

    2024-01-17 20:56:11
  • php文件上传类完整实例

    2023-11-22 04:32:28
  • asp中获取内容中所有图片与获取内容中第一个图片的代码

    2011-02-20 10:51:00
  • Laravel框架文件上传功能实现方法示例

    2023-11-15 19:16:31
  • python urllib.request模块的使用详解

    2023-03-27 18:19:15
  • Python自动重试HTTP连接装饰器

    2022-02-18 12:55:55
  • XML简易教程之二

    2008-09-05 17:19:00
  • asp之家 网络编程 m.aspxhome.com