js实现浮动框跟随页面滚动,最后停留在原来位置
2015-11-10 11:41
816 查看
左边悬浮的二维码会跟随页面向上或者向下滚动,最后停留在原来的位置。
<div style="background:red; width:1000px; height:7000px; margin:auto;"> </div> <div id="aa" style="position: absolute;right: 0px; top: 4600px;"><img src="001.jpg"/></div> <script> function scrollx(p){ var d = document,dd = d.documentElement,db = d.body,w = window,o = d.getElementById(p.id),ie6 = /msie 6/i.test(navigator.userAgent),style,timer; if(o){ o.style.cssText +=";position:"+(p.f&&!ie6?'fixed':'absolute')+";"+(p.l==undefined?'left:0;':'left:'+p.l+'px;')+(p.t!=undefined?'top:'+p.t+'px':'bottom:0'); if(p.f&&ie6){ o.style.cssText +=';left:expression(documentElement.scrollLeft + '+(p.l==undefined?dd.clientWidth-o.offsetWidth:p.l)+' + "px");top:expression(documentElement.scrollTop +'+(p.t==undefined?dd.clientHeight-o.offsetHeight:p.t)+'+ "px" );'; dd.style.cssText +=';background-image: url(about:blank);background-attachment:fixed;'; }else{ if(!p.f){ w.onresize = w.onscroll = function(){ clearInterval(timer); timer = setInterval(function(){ //双选择为了修复chrome 下xhtml解析时dd.scrollTop为 0 var st = (dd.scrollTop||db.scrollTop),c; c = st - o.offsetTop + (p.t!=undefined?p.t:(w.innerHeight||dd.clientHeight)-o.offsetHeight); if(c!=0){ o.style.top = o.offsetTop + Math.ceil(Math.abs(c)/10)*(c<0?-1:1) + 'px'; }else{ clearInterval(timer); } },10) } } } } } scrollx({ id:'aa', t:300, }) /* id 你要滚动的内容的id l 横坐标的位置 不写为紧贴右边 t 你要放在页面的那个位置默认是贴着底边 0是贴着顶边 f 1表示固定 不写或者0表示滚动 */ </script>
相关文章推荐
- 使用Gson进行json数据转换(list to json 和json to list)
- extjs 3.x简单的异步树 并实现展开时重新加载数据的实现
- PHP输出&javascript输出
- js对象转json,json转js对象
- javascript适合移动端的日期时间拾取器
- Extjs控件属性
- 只有20行Javascript代码!手把手教你写一个页面模板引擎
- JSP内置对象--response对象 (addCookie(),setHeader(),sendRedirect())
- 使用freemarker自动生成dao,service,model,action,jsp
- javascript学习之路--变量重复声明
- js方法
- Console命令详解,让调试js代码变得更简单
- 验证码js不能更新
- 去除所有空格 JS 正则表达式
- ActionResult返回Json时的exception
- MVC中使用js拼接的元素验证问题
- javascript学习之路--判断浏览器是否支持javascript解释型脚本语言。
- 网页JS获取当前地理位置(省市区)
- 火狐 IE获取JS event对象
- js图片轮播手动切换效果