这是一个基本实现思路,如果有新手和我一样没什么事,喜欢瞎研究话,可以参考下。

一、Html

  <div class="scroll_con">
<div class="scroll_text">
这里是你的需要显示在滚动条框内文本内容......
</div>
</div>

二、Css

  /*这里是让用户鼠标在里面不能选中文字,避免拖动的时候出错*/
body { -moz-user-select: none; /*火狐*/ -webkit-user-select: none; /*webkit浏览器*/ -ms-user-select: none; /*IE10*/ -khtml-user-select: none; /*早期浏览器*/ user-select: none; } * { margin:; padding:; border:; } /*滚动文本及滚动条大框*/
.scroll_con { width: 500px; height: 500px; background-color: #5c0af7; position: relative; overflow-y: hidden; } /*滚动文本*/
.scroll_text { width: 480px; font-size: 14px; word-break:break-word; color: #ffffff; position: absolute; left:; top:; } /*滚动条整体框*/
.scroll { height: 500px; background-color: #2e03c4; position: absolute; left: 486px; top:; }
.scroll,.scroll .scroll_cen, .scroll .scroll_up, .scroll .scroll_down { width: 14px; }
/*滚轮上下按钮*/
.scroll .scroll_up, .scroll .scroll_down { height: 20px; line-height: 20px; background-color: #7263f8; color: #ffffff; font-size: 14px; font-weight: bold; text-align: center; }
.scroll .scroll_up:hover, .scroll .scroll_down:hover { background-color: #9da2f8; cursor: pointer; }
/*滚动滚动轨道*/
.scroll .scroll_cen { height: 460px; background-color: #2e03c4; position: relative; }
.scroll .scroll_cen .scroll_button { width: 12px; margin: 0px 1px; background-color: #7263f8; border-radius: 5px; position: absolute; cursor: pointer; }

三、JavaScript

  $(function () {

             //添加滚动条
scrollHTML = "";
scrollHTML += "<div class='scroll_up'>∧</div>"; //上微调按钮
scrollHTML += "<div class='scroll_cen'><div class='scroll_button'></div></div>"; //中间轨道层即内滑动按钮
scrollHTML += "<div class='scroll_down'>∨</div>"; //下微调按钮
$(".scroll_con").append("<div class='scroll'> " + scrollHTML + "</div>"); //在HTML中输出滚动条整体 var text_hidden = $(".scroll_con").height(); //文本内容显示高度
var text_show = $(".scroll_text").height(); //文本内容实际高度
var scroll_b = $(".scroll_button"); //获取滚动按钮
var text_p = text_hidden / text_show; //计算显示内容占实际内容的多少
var bH_max = 460; //定义滚动按钮最大显示长度
var bH = text_p * bH_max; //定义滚动按钮长度随文本实际内容成正比改变
if (text_p >= 1) { //判断当文本没有超出显示框时
$(".scroll").css("display", "none"); //滚动条不显示
} else { //否则
$(".scroll").css("display", "block"); //显示滚动条
scroll_b.css("height", bH + "px"); //且按钮长度为随正比改变的值
} //鼠标拖动div事件
var needMove = false, //是否需要拖动
mouseY = 0; //清空当前鼠标指针坐标 scroll_b.mousedown(function (event) { //当鼠标按下时
needMove = true; //需要滑动
var bH_Top = scroll_b.position().top; //获取鼠标按下时滚动按钮的top
mouseY = event.pageY - bH_Top; //计算此时的鼠标指针坐标
}); $(document).mouseup(function (event) { //当鼠标离开时
needMove = false; //不需要滑动
}); $(document).mousemove(function (event) { //当鼠标移动时
if (needMove) {//如果为需要滑动
var sMouseY = event.pageY; //获取鼠标移动后在页面的当前坐标
var bH_Top = sMouseY - mouseY; //计算滚动按钮此时的top
var textY = bH_Top / bH_max * text_show; //根据前面计算出的占比计算文本此时应该显示的坐标 if (bH_Top <= 0) { //如果此时滚动按钮的top<0
scroll_b.css("top", 0);
$(".scroll_text").css("top", 0);
return;
} if (bH_Top >= bH_max - bH) { //如果此时滚动按钮的top>=滚动按钮可滚动的最大范围
scroll_b.css("top", bH_max - bH);
$(".scroll_text").css("top", text_hidden - text_show);
return;
}
scroll_b.css("top", bH_Top);
$(".scroll_text").css("top", -textY);
}
return;
}); //上微调按钮点击事件
var goThread = ""; $(".scroll_up").mouseup(function () {
clearInterval(goThread);
}) $(".scroll_up").mousedown(function () {
clearInterval(goThread);
goThread = setInterval(function () { bH_Top = scroll_b.position().top; //获取鼠标按下时滚动按钮的top
var h = 0;
h += 5;
var Toping = bH_Top - h;
if (bH_Top <= 0 || Toping <= 0) { //如果此时滚动按钮的top<0
scroll_b.css("top", 0);
$(".scroll_text").css("top", 0);
return;
}
var textY = bH_Top / bH_max * text_show;
scroll_b.css("top", bH_Top - h);
$(".scroll_text").css("top", -textY); }, 300);
}); $(".scroll_up").click(function () {
bH_Top = scroll_b.position().top; //获取鼠标按下时滚动按钮的top
var h = 0;
h += 5;
var Toping = bH_Top - h;
if (bH_Top <= 0 || Toping <= 0) { //如果此时滚动按钮的top<0
scroll_b.css("top", 0);
$(".scroll_text").css("top", 0);
return;
}
var textY = bH_Top / bH_max * text_show;
scroll_b.css("top", bH_Top - h);
$(".scroll_text").css("top", -textY);
}); //下微调按钮点击事件
$(".scroll_down").mouseup(function () {
clearInterval(goThread);
}) $(".scroll_down").mousedown(function () {
clearInterval(goThread);
goThread = setInterval(function () { bH_Top = scroll_b.position().top; //获取鼠标按下时滚动按钮的top
var h = 0;
h += 5;
var Downing = bH_Top + h;
if (bH_Top >= bH_max - bH || Downing >= bH_max - bH) { //如果此时滚动按钮的top>=滚动按钮可滚动的最大范围
scroll_b.css("top", bH_max - bH);
$(".scroll_text").css("top", text_hidden - text_show);
return;
}
var textY = bH_Top / bH_max * text_show;
scroll_b.css("top", bH_Top + h);
$(".scroll_text").css("top", -textY); }, 300);
}); $(".scroll_down").click(function () {
bH_Top = scroll_b.position().top; //获取鼠标按下时滚动按钮的top
var h = 0;
h += 5;
var Downing = bH_Top + h;
if (bH_Top >= bH_max - bH || Downing >= bH_max - bH) { //如果此时滚动按钮的top>=滚动按钮可滚动的最大范围
scroll_b.css("top", bH_max - bH);
$(".scroll_text").css("top", text_hidden - text_show);
return;
}
var textY = bH_Top / bH_max * text_show;
scroll_b.css("top", bH_Top + h);
$(".scroll_text").css("top", -textY);
}); //滚轮事件(这里调用了一个插件jQuery Mousewheel)
$(".scroll_con").bind("mousewheel", function (event, delta, deltaX, deltaY) {
if (delta==1) { //滚动向上滚动时
bH_Top = scroll_b.position().top; //获取鼠标按下时滚动按钮的top
var h = 0;
h += 5;
var Toping = bH_Top - h;
if (bH_Top <= 0 || Toping <= 0) { //如果此时滚动按钮的top<0
scroll_b.css("top", 0);
$(".scroll_text").css("top", 0);
return;
}
var textY = bH_Top / bH_max * text_show;
scroll_b.css("top", bH_Top - h);
$(".scroll_text").css("top", -textY);
}
if (delta == -1) { //滚动向下滚动时
bH_Top = scroll_b.position().top; //获取鼠标按下时滚动按钮的top
var h = 0;
h += 5;
var Downing = bH_Top + h;
if (bH_Top >= bH_max - bH || Downing >= bH_max - bH) { //如果此时滚动按钮的top>=滚动按钮可滚动的最大范围
scroll_b.css("top", bH_max - bH);
$(".scroll_text").css("top", text_hidden - text_show);
return;
}
var textY = bH_Top / bH_max * text_show;
scroll_b.css("top", bH_Top + h);
$(".scroll_text").css("top", -textY);
}
return; }); })

四、OK,这样就搞定一个自定义的滚动条了,最后总结下,将复用的方法整合,优化下代码。封装成一个方法就完成啦!

JavaScript学习笔记-自定义滚动条的更多相关文章

  1. JavaScript学习笔记- 自定义滚动条插件

    此滚动条仅支持竖向(Y轴) 一.Css /*这里是让用户鼠标在里面不能选中文字,避免拖动的时候出错*/ body { -moz-user-select: none; /*火狐*/ -webkit-us ...

  2. javascript 学习之自定义滚动条加滚轮事件

    要自己写一个自定义滚动条加上滚轮事件,之前的没有滚轮事件不完整,今天整理了一个. 1.滚轮事件是不兼容的,firefox中是必需要用事件绑定的添加,用的DOMMouseScroll,当滚动鼠标的时候, ...

  3. JavaScript学习笔记-自定义集合类

    //集合类Set( ES6标准才有的类,目前兼容性较差)//自定义集合类:extend = function (o,p){ //定义一个复制对象属性的类函数 for(var x in p){ o[x] ...

  4. JavaScript:学习笔记(2)——基本概念与数据类型

    JavaScript:学习笔记(2)——基本概念与数据类型 语法 1.区分大小写.Test 和 test 是完全不同的两个变量. 2.语句最好以分号结束,也就是说不以分号结束也可以. 变量 1.JS的 ...

  5. Java程序猿的JavaScript学习笔记(汇总文件夹)

    最终完结了,历时半个月. 内容包含: JavaScript面向对象特性分析,JavaScript高手必经之路. jQuery源代码级解析. jQuery EasyUI源代码级解析. Java程序猿的J ...

  6. Java程序猿的JavaScript学习笔记(8——jQuery选择器)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

  7. Java程序猿JavaScript学习笔记(2——复制和继承财产)

    计划和完成在这个例子中,音符的以下序列: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaSc ...

  8. Java程序猿的JavaScript学习笔记(3——this/call/apply)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

  9. Java程序猿JavaScript学习笔记(4——关闭/getter/setter)

    计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...

随机推荐

  1. C#设计模式(21)——责任链模式

    一.引言 在现实生活中,有很多请求并不是一个人说了就算的,例如面试时的工资,低于1万的薪水可能技术经理就可以决定了,但是1万~1万5的薪水可能技术经理就没这个权利批准,可能就需要请求技术总监的批准,所 ...

  2. iOS UIButton 图片文字上下垂直布局 解决方案

    实现如图所示效果: 这是一个UIButton,需要改变image和title相对位置. 解决如下: //设置文字偏移:向下偏移图片高度+向左偏移图片宽度 (偏移量是根据[图片]大小来的,这点是关键)b ...

  3. iOS 读取相册二维码,兼容ios7(使用CIDetector 和 ZXingObjC)

    ios从相册读取二维码,在ios8以上,苹果提供了自带的识别图片二维码的功能,这种方式效率最好,也是最推荐的,但是如果你的系统需要向下兼容ios7,就必须用其他方式. 这里我选择的是 ZXingObj ...

  4. 错误 未能找到类型或命名空间名称 (是否缺少 using 指令或程序集引用?)

    有时发现,明明引用了,结果却提示未引用, 这时就有可能是两个程序集的目标框架类型不一致导致的(在程序集属性面板里改下即可).

  5. netbeans设置语言

    netbeans的界面语言 默认是按系统语言 设的. 想要自己指定的话,加上以下参数就可以了. 中文 --locale zh:CN 英文 --locale en:US 日文 --locale ja:J ...

  6. 非常不错的点餐系统应用ios源码完整版

    该源码是一款非常不错的点餐系统应用,应用源码齐全,运行起来非常不错,基本实现了点餐的一些常用的功能,而且界面设计地也很不错,是一个不错的ios应用学习的例子,喜欢的朋友可以下载学习看看,更多ios源码 ...

  7. C语言中内存分配那些事儿

    C程序的内存结构 C语言的之所以复杂,首先它的内存模型功不可没.不像某些那样的高级语言只需要在使用对象的时候,用new创建.所有之后的事情,你不需要操心.对于C语言,所有与内存相关的东西,都需要熟悉, ...

  8. 清除MAC OS X上的流氓软件 - advance mac cleaner

    自3721开天辟地以来,流氓软件从来就没有消停过,连MAC OS X都难逃流氓软件的骚扰. 近日,因为从SourceForge上下载了一个软件安装包,结果中招了——莫名其妙被安装了advance ma ...

  9. ADO.Net属性扩展

    属性扩展 大体意思:有外键关系时将代号化信息处理成原始文字 如:Info表中的民族列显示的是民族代号处理成Nation表中的民族名称 需要在Info类里面扩展一个显示nation名称的属性 using ...

  10. JS客户端判断

    <script language="javascript" type="text/javascript"> function browserDete ...