分享刚写的一个仿Fixed的js

constanine_xia 2013-09-09 11:21:59
如题。但是还有些小问题,希望发现的大神一起帮忙解决
代码如下
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title> new document </title>
<style type="text/css">
html,body{
width:100%;
height:100%;
}
div,body{
margin:0px;
padding:0px;
}

#show1{
background-color:red;
margin:10px;
width:53px;
height:120px;
color:white;
float:left;
}

#show2{
background-color:red;
margin:10px;
width:150px;
height:60px;
color:white;
position:absolute;
}

#show3{
margin:10px;
width:500px;
color:white;
float:left;
}

.x120div{
background-color:red;
margin:0px;
padding:0px;
width:700px;
height:60px;
color:white;
}
</style>
</head>


<script type="text/javascript">

window.onload = function () {
var element = window;
var showheight=0;
var maxheight=document.body.scrollHeight;
var fianlScreen=document.body.offsetHeight ;
if (element.addEventListener) { //FireFox
element.addEventListener("DOMMouseScroll", function (event) {
mousewheel(event);
});
}
else { //IE、Chrome
element.onmousewheel = function (event) {
mousewheel(event);
}
}

var mousewheel = function (ev) {
var ev = window.event || ev;
var show=document.getElementById("show2");
var scrollTop = element.scrollTop;
var scrollHeight = element.scrollHeight;
var height = element.clientHeight;
var delta = ev.type == 'DOMMouseScroll' ? ev.detail * 34 : ev.wheelDelta;
showheight+=delta;
if(showheight<0){
showheight=1;
}else if(showheight>maxheight-fianlScreen){
showheight=maxheight-fianlScreen;
}
show.style.top=showheight+"px";
}
}
</script>
<body>
<!--<div onscroll="document.getElementById('f').style.top=this.scrollTop+'px'"
style="height:80px;width:100px;overflow:auto;border:1px solid #000;">
1<br/>2<br/>3<br/>4<br/>5<br/>6<br/>
1<br/>2<br/>3<br/>4<br/>5<br/>6<br/>
<div id="f" style="height:10px;width:10px;background:red;position:absolute;top:0"></div>
</div>-->
<div id="show2"></div>
<div id="show3">
<div class="x120div" style="background-color:#FF44AA ;">1</div>
<div class="x120div" style="background-color:#FF3333 ;">2</div>
<div class="x120div" style="background-color:#FF7744 ;">3</div>
<div class="x120div" style="background-color:#FFAA33;">4</div>
<div class="x120div" style="background-color:#FFCC22;">5</div>
<div class="x120div" style="background-color:#FFFF33;">6</div>
<div class="x120div" style="background-color:#CCFF33;">7</div>
<div class="x120div" style="background-color:#99FF33;">8</div>
<div class="x120div" style="background-color:#33FF33;">9</div>
<div class="x120div" style="background-color:#33FFAA;">10</div>
<div class="x120div" style="background-color:#33FFFF;">11</div>
<div class="x120div" style="background-color:#33CCFF;">12</div>
<div class="x120div" style="background-color:#5599FF;">13</div>
<div class="x120div" style="background-color:#5555FF;">14</div>
<div class="x120div" style="background-color:#7744FF;">15</div>
<div class="x120div" style="background-color:#FF44AA ;">1</div>
<div class="x120div" style="background-color:#FF3333 ;">2</div>
<div class="x120div" style="background-color:#FF7744 ;">3</div>
<div class="x120div" style="background-color:#FFAA33;">4</div>
<div class="x120div" style="background-color:#FFCC22;">5</div>
<div class="x120div" style="background-color:#FFFF33;">6</div>
<div class="x120div" style="background-color:#CCFF33;">7</div>
<div class="x120div" style="background-color:#99FF33;">8</div>
<div class="x120div" style="background-color:#33FF33;">9</div>
<div class="x120div" style="background-color:#33FFAA;">10</div>
<div class="x120div" style="background-color:#33FFFF;">11</div>
<div class="x120div" style="background-color:#33CCFF;">12</div>
<div class="x120div" style="background-color:#5599FF;">13</div>
<div class="x120div" style="background-color:#5555FF;">14</div>
<div class="x120div" style="background-color:#7744FF;">15</div>
</div>


</body>
</html>
...全文
124 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
constanine_xia 2013-09-09
  • 打赏
  • 举报
回复
附。就大神给个关于手机ie的监听事件的说明吧。。为什么pc的ie可行。手机滚屏没监听到呢
2022年11月4日-2022年11月14日购买当前课程赠送课程学习地址如下:https://edu.csdn.net/course/detail/32434https://edu.csdn.net/course/detail/35658https://edu.csdn.net/course/detail/30223https://edu.csdn.net/course/detail/32408https://edu.csdn.net/course/detail/32429注:因赠送课程不会出现在已订阅课程列表中,以下课程学习地址一定要收藏保存。#课程服务 在线答疑:本课程设有专门的讨论留言区,学习中遇到任何问题,直接给老师留言即可,老师都会及时进行回复。远程协助:如果遇到复杂问题,老师还可进行远程协助,这个一般可不是一两百元的课程就能享受到的。源码分享:为了让大家更好的进行项目实战,老师还将课程中涉及到的所有源码分享给学员,按照视频中的提示进行下载即可。在CSDN分享C++ Qt开发知识已经有6年了,感谢众多博友对我的支持,了解到很多人对Qt的使用还是有些困扰,例如Qt环境搭建,Qt布局的使用,如何使用Qt编写复杂的界面,如何自定义非标控件,Qt如何和Web交互,Qt和后台接口如何交互等;经过这几年的整理,我决定出这套《Qt高级开发视频教程》,带领大家学习Qt高级开发知识,学习如何使用Qt开发企业级别的项目;通过本课程的学习,大家将会达到企业招聘的中高级要求。为了照顾零基础学员,本课程第一章会介绍Qt环境搭建、QtCreator / VS2019的基本使用方法,Qt整体架构、Qt信号机制,Qt内存管理等知识。即使没有Qt开发的学习经验,也能跟着课程顺利学习。课程核心知识点地图如下: 课程每章核心知识点介绍如下: 第一章:介绍Qt环境搭建、QtCreator / VS2019的基本使用方法,Qt整体架构、Qt信号机制,Qt内存管理等知识。第二章:了解到很多学员对于Qt界面布局很不熟悉,将会详细介绍Qt设计器布局,以及如何C++代码手写布局,从常见的企业级项目入手,带领大家学会各种布局的实现,例如WPS、腾讯会议、优酷、迅雷等界面的实现;界面布局会了,这是企业项目开发的第一步,还有更重要的无边框窗口,如何设计一个合理的无边框窗口很重要,第三/四章:详细介绍如何实现一个无边框窗口,如何自定义标题栏,如何实现拖拽拉伸;第四章将会介绍如何自定义非标控件,优化Qt界面。第五章:介绍Qt web混合编程,一个商用项目,必然会涉及到web交互,这也是很多Qt开发者的弱项,这一章讲详细介绍C++ Qt web混合开发。第六章:既然是做企业级项目,必然需要和后台交互,http编程也是必要的,将详细介绍http编程,用户注册,登录,后台接口请求等知识;通过第五、六章的学习,将会是你的Qt开发技术更上一层楼。第七章:介绍Qt并发编程,耗时任务处理,进程调用等知识。第八、九章:讲解 Qt 比较重要的知识,图形视图结构,以及MVD模式;通过这两章的学习,大家会对图形视图有更好的了解。第十章:本章是独立章节,主要介绍Qt中一些特殊技巧,项目编译,dpi适配、多语言等知识。第十一章:是我们的企业级项目实战:实现一个视频会议客户端,本项目可以进行多人视频通话,直播,桌面分享等功能,本项目我会从零开始,进行项目搭建,功能调试,bug fixed, 带领大家做一个企业级项目。希望通过本课程的学习,大家的C++ Qt开发技术能有质的飞越,能找到自己心仪的工作。课程中如果讲的不对的地方,请大家指出,我及时修正,我也只是一个普通开发者,也不是所有的技术都会,尽我所能,把我所会的教给大家,让我们一起为Qt的发展,尽一份绵薄之力。 下面是本课程一些项目的截图: 1 可以滑动的设置界面         2 所有图形的绘制       3 视频播放器          4 高仿youku界面         5 视频会议         相信通过本课程的学习,大家有能力实现绝大部分客户端项目,从此用C++ Qt再也不会有难写的界面。

87,907

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧