0
点赞
收藏
分享

微信扫一扫

原生JS实现拖拽进度条、滚动鼠标显示相应的内容


 今天要分享的是运用原生JS实现拖拽进度条、滚动鼠标显示相应的内容,实现效果如下:

原生JS实现拖拽进度条、滚动鼠标显示相应的内容_ide

 以下是代码实现,欢迎大家复制粘贴。

<!DOCTYPE html>
<html>

<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>原生JS实现拖拽进度条、滚动鼠标显示相应的内容</title>
<style>
#slider {
width: 400px;
height: 20px;
background: #CCC;
position: relative;
margin: 20px auto;
}

#block {
width: 20px;
height: 20px;
background: red;
cursor: pointer;
position: absolute;
}

#box {
width: 200px;
height: 300px;
margin: 0 auto;
border: 1px solid black;
position: relative;
overflow: hidden;
}

#content {
position: absolute;
}
</style>
</head>

<body>

<div id="slider">
<div id="block"></div>
</div>

<div id="box">
<div id="content">
关于我们 我们是一支独具特色的IT培训团队,反对传统IT教育枯燥 乏味的教学模式,提供一种全新的快乐学习方法!
目前主要针对的是javascript培训,同时还提供了css教程、javascript 视频、js特效等,最新推出了外地学员们喜欢的javascript网络课程服
务,同时还为处于javascript入门阶段的朋友录制了大量javascript视 频,其中涉及了大量javascript基础知识,希望我们推出的javascript 网络培训课程能带给大家更多惊喜。
关于讲师: 我们的讲师来自中国最具吸引力的IT企业,如淘宝、ShopEx等。 前端开发讲师:Leo WEB 前端开发工程师(5年)、CSS 精品课 程讲师(3年),公司创始人;曾任北京科尔威视、ShopEx
北京营 销中心 ECMall 项目前端架构师;精通 XHTML+CSS 架构,深刻理解 W3C 标准,熟练掌握系统的浏览器兼容性解决方案,擅长大型网站前
端架构及调试各类页面错位等诸多兼容性问题的疑难杂症;专注于网站 用户体验性研究,并在视频、电子商城、教育平台、企业级应用站点拥 有数量庞大的案例和多年实战经验;
</div>
</div>

<script>

function myAddEvent(obj, event, callback) {
// 针对IE浏览器
if (obj.attachEvent) {
obj.attachEvent('on' + event, callback);
// 针对火狐 和Chrome浏览器
} else {
// DOM事件只能通过addEventListener来添加
obj.addEventListener(event, callback, false);
}
}

window.onload = function () {

var slider = document.getElementById('slider');
var block = document.getElementById('block');
var box = document.getElementById('box');
var content = document.getElementById('content');

// 鼠标滚动时
function onMouseWheel(ev) {
// 一切事件的详细信息都包括在事件对象里面
var myEvent = ev || event;

// 处理兼容性,记录上向上滚的还是向下滚的
var down = true;

// wheelDelta IE下独有的
// myEvent.detail Firefox下的

// 当滚动距离小于0时为false,大于0时为true
down = myEvent.wheelDelta ? myEvent.wheelDelta < 0 : myEvent.detail > 0;

if (down) {
// 让block的left值加10
setLeft(block.offsetLeft + 10);

} else {
// 让block的left值减10
setLeft(block.offsetLeft - 10);
};

// 针对Firefox下阻止事件默认,防止滚动时DIV和页面滚动一起发生变化
if (myEvent.preventDefault) {
myEvent.preventDefault();
};

// 针对IE和Chrome下阻止默认,防止滚动时DIV和页面滚动一起发生变化
return false;
}

// IE attach mousewheel
// FF add DOMMouseScroll
// Chrome add mousewheel
// 基于以上情况,用兼容性方法添加事件(滑块上滚动)
myAddEvent(slider, 'mousewheel', onMouseWheel);
myAddEvent(slider, 'DOMMouseScroll', onMouseWheel);

// 基于以上情况,用兼容性方法添加事件(内容上滚动)
myAddEvent(box, 'mousewheel', onMouseWheel);
myAddEvent(box, 'DOMMouseScroll', onMouseWheel);

// 鼠标按下时
block.onmousedown = function (ev) {

var myEvent = ev || event;

var disX = myEvent.clientX - block.offsetLeft;

// 鼠标移动时
document.onmousemove = function (ev) {
var myEvent = ev || event;
var left = myEvent.clientX - disX;

setLeft(left);
};
// 鼠标抬起时
document.onmouseup = function () {
document.onmousemove = null;
document.onmouseup = null;
};
};

// 设置滑块的left值
function setLeft(left) {
// 限制范围
if (left < 0) {
left = 0;
} else if (left > slider.offsetWidth - block.offsetWidth) {
left = slider.offsetWidth - block.offsetWidth;
};

block.style.left = left + 'px';

// 计算滚动距离相对滚动范围的比例
var scale = left / (slider.offsetWidth - block.offsetWidth);

// 让content随着滚动的距离上下滑动显示内容
content.style.top = -(content.offsetHeight - box.offsetHeight) * scale + 'px';

}
};
</script>
</body>

</html>

举报

相关推荐

0 条评论