可以设置左边菜单项div的overflow
x:auto;overlfow
y:auto;这样就会自动生成了滚动条
但是大家都知道自带的不好看
接下来就是重点了
如何修改滚动条的样式呢?感兴趣的朋友可以了解下本文
最近做项目中有一个模块是用于实时监控的左边有个菜单栏用于显示所有的设备那当然是从数据库中动态获取的了右边是个iframe用于显示监控画面 本来这个功能并不复杂左边的菜单项是利用dtreejs来实现的可时当功能实现完成之后却发现一个问题就是左边菜单栏中的设备名有的会很长会 超出了div的长度准确说是左边iframe的宽度和长度不够那么这时就必须要利用滚动条了可以设置左边菜单项div的overflow x:auto;overlfowy:auto;这样就会自动生成了滚动条但是大家都知道自带的不好看接下来就是重点了如何修改滚动条的样式呢?
经过从网上的不断搜索发现有两种方法
第一种方法利用CSS提供的样式一共是种属性吧在这里不做详细介绍网上很多这方面的资料
第二种方法自己写一个新的滚动条即不用div自带的滚动条这样想要什么样的效果就有什么样的效果具体实现在网上搜了很多可以发现基本上只有竖向滚动条而没有横向滚动条无奈之下自己利用jquery写另一个滚动条当然也借鑒了只有竖向滚动条的程序
说 一下具体实现思路目标div 即需要生成滚动条的div里面嵌套了个div分别是用于显示内容的div_content显示竖向滚动条的div_H显示横向滚动条的 div_W具体布局就是按照自带滚动条的div的布局一样然后显示滚动条的div即div_H和div_W有各自包含了个div即左右箭头个 滚动条个具体代码如下
复制代码 代码如下:
if($(_self)
children("
jscroll
c")
height()==null){
//添加内容框(div)
$(_self)
wrapInner("<div class=
jscroll
c
style=
top:
px;z
index:
;zoom:
;position:relative;
></div>");
//添加竖向滚动条
$(_self)
append("<div class=
jscroll
e
unselectable=
on
style=
height:
%;top:
px;right:
;
moz
user
select:none;position:absolute;overflow:hidden;z
index:
;
><div class=
jscroll
u
style=
position:absolute;top:
px;width:
%;right:
;background:blue;overflow:hidden
></div><div class=
jscroll
h
unselectable=
on
style=
background:green;position:absolute;left:
;
moz
user
select:none;border:
px solid
></div><div class=
jscroll
d
style=
position:absolute;bottom:
px;width:
%;left:
;background:blue;overflow:hidden
></div></div>");
//添加横向滚动条
$(_self)
append("<div class=
jscroll
s
unselectable=
on
style=
width:
px;bottom:
px;left:
;
moz
user
select:none;position:absolute;overflow:hidden;z
index:
;
><div class=
jscroll
l
style=
position:absolute;bottom:
px;height:
%;left:
;background:blue;overflow:hidden
></div><div class=
jscroll
g
unselectable=
on
style=
height:
%;background:green;position:absolute;left:
;
moz
user
select:none;border:
px solid
></div><div class=
jscroll
r
style=
position:absolute;bottom:
px;height:
%;right:
;background:blue;overflow:hidden
></div></div>");
}
然后无非就是一些判断div的内容是否超过了div的范围监听事件的添加具体代码可见我的下载资源