javascript滚动条之ScrollBar.js
ScrollBar.js是一个仅仅120行的滚动条JS插件,使用非常方便
详情阅读:https://git.oschina.net/wuquanyao/scrollbar.js
/*=================================* ScrollBar.js beta* Author:wuquanyao* Email:wqynqa@163.com*=================================*/var ScrollBar = {};(function(ScrollBar){var parent,root,track,bar,tx,ch,h,sh,rate;ScrollBar.adapter = function(config){init(config);}function init(config){parent = document.querySelector(config['selector']);root = parent.parentNode;createBar();mouseaction();}function createBar(){track = document.createElement('div');track.setAttribute('class','scroll-track');bar = document.createElement('div');bar.setAttribute('class','scroll-bar');track.appendChild(bar);root.appendChild(track);sh = root.scrollHeight;ch = root.offsetHeight;tx = root.offsetTop;h = ch/sh*ch;if(h<30){bar.style.height = '30px';h = 30;}else{bar.style.height = h+'px';}rate = (sh-ch)/(ch-h);}function mouseaction(){function eventparse(obj,type,func){if(document.attachEvent){var events = {click:'onclick',mouseover:'onmouseover',mousemove:'onmousemove',mouseout:'onmouseout',mousedown:'onmousedown',mouseup:'onmouseup',wheel:'DOMMouseScroll'};obj.attachEvent(events[type],func);}else{var events = {click:'click',mouseover:'mouseover',mousemove:'mousemove',mouseout:'mouseout',mousedown:'mousedown',mouseup:'mouseup',wheel:'DOMMouseScroll'};obj.addEventListener(events[type],func,false);}}function init(){var bool = false,v;eventparse(bar,'mousedown',function(event){bool = true;});eventparse(document,'mousemove',function(event){if(bool){if(event.clientY<=(tx+10)){v = 0;}else if(event.clientY>=(tx+ch-h)){v = tx+ch-h;}else{v = event.clientY;}parent.style.transform = 'translate(0px,'+(-v*rate)+'px)';bar.style.transform = 'translateY('+v+'px)';}});eventparse(document,'mouseup',function(event){bool = false;});// eventparse(track,'click',function(event){// event.stopPropagation();// bar.style.transition = 'all 0ms ease 0ms';// if(event.clientY<(tx+h)){// bar.style.transform = 'translate(0px,0px)';// }else if(event.clientY>=(tx+ch-h)){// bar.style.transform = 'translate(0px,'+(tx+ch-h)+'px)';// }else{// bar.style.transform = 'translate(0px,'+(event.clientY-h/2)+'px)';// }// parent.style.transform = 'translate(0px,'+((-event.clientY+tx)*rate)+'px)';// });var offset=0;if (window.navigator.userAgent.indexOf("Firefox") >= 0) {eventparse(parent,'wheel',wheelEvent);}else{parent.onmousewheel=parent.onmousewheel=wheelEvent;}function wheelEvent(e){var transform,bO,wv = (e.detail/3*20) || (-(e.wheelDelta/120*20));if((offset<(sh-ch) &&(offset>=0))){transform = 'translate(0px,'+(-offset)+'px)';bO = 'translateY('+(offset/rate)+'px)';offset = ((offset+wv)>(sh-ch))?offset:( ((offset+wv)<=0)?0:(offset+wv) );}bar.style.transform = bO;parent.style.transform = transform;}}init();}})(ScrollBar);
javascript滚动条之ScrollBar.js的更多相关文章
- 【JavaScript】使用纯JS实现多张图片的懒加载(附源码)
一.效果图如下 上面的效果图,效果需求如下 1.还没加载图片的时候,默认显示加载图片背景图 2.刚开始进入页面,自动加载第一屏幕的图片 3.下拉界面,当一张图片容器完全显露出屏幕,即刻加载图片,替换背 ...
- 初探JavaScript(三)——JS带我"碰壁"带我飞
已经写了两篇关于小白的JavaScript之行,不可否认,每一种语言都有其精华与糟粕之处,来不及细细体味其精华奥妙,也没法对其评头论足,只能先了解,后深入.到目前为止已经看完<JavaScrip ...
- 初探JavaScript(二)——JS如何动态操控HTML
除去五一三天,我已经和<JavaScript Dom编程艺术>磨合了六天,第一印象很好.慢慢的,我发现这是一块排骨,除了肉还有骨头.遇到不解的地方就会多看几遍,实在不懂的先跳过,毕竟,初次 ...
- 强大的JavaScript动画图形库mo.js
最近在学习前端动画方面知识时发现了挺有趣的一个动画的图形库mo.js,页面效果真是酷炫,有兴趣的同学可以研究下:). 酷炫的效果: 以下是官方的demo效果,更多详情请查看 mo.js http:// ...
- 省市县 三级 四级联动Javascript JQ 插件PCASClass.js
想要使用这款组件,需要页面引入 PCASClass.js 核心文件,该文件在您的HTML文档<head>标签之内. <script type="text/javascrip ...
- 【转】《高级前端3.6》JavaScript多线程——Concurrent.Thread.js, WebWork
原文链接:http://www.cnblogs.com/woodk/articles/5199536.html JavaScript多线程,在HTML5 WebWork没出现之前很多人都是用Concu ...
- JavaScript模板引擎Template.js使用详解
这篇文章主要为大家详细介绍了JavaScript模板引擎Template.js使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 template.js 一款 JavaScript 模板引 ...
- 坑人的 Javascript 模块化编程 require.js
坑人的 Javascript 模块化编程 require.js
- 坑人的 Javascript 模块化编程 sea.js
坑人的 Javascript 模块化编程 sea.js 忧伤 加 蛋疼的 开始了 看文档 Sea.js 进行配置 seajs.config({ // 设置路径,方便跨目录调用 paths: { 'ar ...
随机推荐
- 信息安全系统设计基础第四次实验报告20135324&&20135330
课程:信息安全系统设计基础 班级:1353 姓名:杨舒雯 张若嘉 学号:20135324,20135330 实验日期:2015.11.17 15:30-17:30 实验名称:外设驱动程序设计 实验目的 ...
- iOS:界面适配(三)--iPhone不同机型或设备不同尺寸适配(屏幕适配)和系统适配
对于不同苹果设备,各个参数查看<iOS:机型参数.sdk.xcode各版本>. 机型变化 坐标:表示屏幕物理尺寸大小,坐标变大了,表示机器屏幕尺寸变大了: 像素:表示屏幕图片 ...
- survival analysis 生存分析与R 语言示例 入门篇
原创博客,未经允许,不得转载. 生存分析,survival analysis,顾名思义是用来研究个体的存活概率与时间的关系.例如研究病人感染了病毒后,多长时间会死亡:工作的机器多长时间会发生崩溃等. ...
- 学习笔记——Maven实战(五)自动化Web应用集成测试
自动化集成测试的角色 本专栏的上一篇文章讲述了Maven与持续集成的一些关系及具体实践,我们都知道,自动化测试是持续集成必不可少的一部分,基本上,没有自动化测试的持续集成,都很难称之为真正的持续集成. ...
- 『开源』仿SQLServer山寨一个 跨数据库客户端
002 Laura.SqlForever项目简单介绍 相关文章 <『练手』001 Laura.SqlForever架构基础(Laura.XtraFramework 的变迁)> <『练 ...
- C# Winform实现炫酷的透明动画界面
做过.NET Winform窗体美化的人应该都很熟悉UpdateLayeredWindow吧,UpdateLayeredWindow可以实现窗体的任意透明,效果很好,不会有毛边.不过使用这个API之后 ...
- ASP.NET 系列:RBAC权限设计
权限系统的组成通常包括RBAC模型.权限验证.权限管理以及界面访问控制.现有的一些权限系统分析通常存在以下问题: (1)没有权限的设计思路 认为所有系统都可以使用一套基于Table设计的权限系统.事实 ...
- jquery面试需要看的基本东西
1. offset() 方法的学习offset().left offset().top 表示离document的距离.(浏览器可以看到的地方的距离)2. position与offset的区别:a.使用 ...
- 附加到iis进程调试时找不到w3wp.exe
在进程列表的下面,有个show processes in all sessions,把它勾上就能看到了
- Symfony学习--原创。。。。
{{ constant('Symfony\\Component\\HttpKernel\\Kernel::VERSION') }} //显示当前symfony的版本 #div { opacity: 0 ...