jquery插件任意位置浮动固定层

2024-05-12 14:32

本文主要是介绍jquery插件任意位置浮动固定层,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!



/*任意位置浮动固定层*/  
/*没剑(http://regedit.cnblogs.com) 2009-03-04*/  
/*说明:可以让指定的层浮动到网页上的任何位置,当滚动条滚动时它会保持在当前位置不变,不会产生闪动*/  
/*2009-06-10修改:重新修改插件实现固定浮动层的方式,使用一个大固定层来定位 
/*2009-07-16修改:修正IE6下无法固定在top上的问题 
/*09-11-5修改:当自定义层的绝对位置时,加上top为空值时的判断 
这次的方法偷自天涯新版页 
经多次测试,基本上没bug~ 
有问题的朋友欢迎到偶的博客http://regedit.cnblogs.com上提出 
*/  
/*调用: 
1 无参数调用:默认浮动在右下角 
$("#id").floatdiv(); 2 内置固定位置浮动 
//右下角 
$("#id").floatdiv("rightbottom"); 
//左下角 
$("#id").floatdiv("leftbottom"); 
//右下角 
$("#id").floatdiv("rightbottom"); 
//左上角 
$("#id").floatdiv("lefttop"); 
//右上角 
$("#id").floatdiv("righttop"); 
//居中 
$("#id").floatdiv("middle"); 另外新添加了四个新的固定位置方法 middletop(居中置顶)、middlebottom(居中置低)、leftmiddle、rightmiddle 3 自定义位置浮动 
$("#id").floatdiv({left:"10px",top:"10px"}); 
以上参数,设置浮动层在left 10个像素,top 10个像素的位置 
*/  
jQuery.fn.floatdiv=function(location){  //判断浏览器版本  var isIE6=false;  var Sys = {};  var ua = navigator.userAgent.toLowerCase();  var s;  (s = ua.match(/msie ([\d.]+)/)) ? Sys.ie = s[1] : 0;  if(Sys.ie && Sys.ie=="6.0"){  isIE6=true;  }  var windowWidth,windowHeight;//窗口的高和宽  //取得窗口的高和宽  if (self.innerHeight) {  windowWidth=self.innerWidth;  windowHeight=self.innerHeight;  }else if (document.documentElement&&document.documentElement.clientHeight) {  windowWidth=document.documentElement.clientWidth;  windowHeight=document.documentElement.clientHeight;  } else if (document.body) {  windowWidth=document.body.clientWidth;  windowHeight=document.body.clientHeight;  }  return this.each(function(){  var loc;//层的绝对定位位置  var wrap=$("<div></div>");  var top=-1;  if(location==undefined || location.constructor == String){  switch(location){  case("rightbottom")://右下角  loc={right:"0px",bottom:"0px"};  break;  case("leftbottom")://左下角  loc={left:"0px",bottom:"0px"};  break;    case("lefttop")://左上角  loc={left:"0px",top:"0px"};  top=0;  break;  case("righttop")://右上角  loc={right:"0px",top:"0px"};  top=0;  break;  case("middletop")://居中置顶  loc={left:windowWidth/2-$(this).width()/2+"px",top:"0px"};  top=0;  break;  case("middlebottom")://居中置低  loc={left:windowWidth/2-$(this).width()/2+"px",bottom:"0px"};  break;  case("leftmiddle")://左边居中  loc={left:"0px",top:windowHeight/2-$(this).height()/2+"px"};  top=windowHeight/2-$(this).height()/2;  break;  case("rightmiddle")://右边居中  loc={right:"0px",top:windowHeight/2-$(this).height()/2+"px"};  top=windowHeight/2-$(this).height()/2;  break;  case("middle")://居中  var l=0;//居左  var t=0;//居上  l=windowWidth/2-$(this).width()/2;  t=windowHeight/2-$(this).height()/2;  top=t;  loc={left:l+"px",top:t+"px"};  break;  default://默认为右下角  location="rightbottom";  loc={right:"0px",bottom:"0px"};  break;  }  }else{  loc=location;  alert(loc.bottom);  var str=loc.top;  //09-11-5修改:加上top为空值时的判断  if (typeof(str)!= 'undefined'){  str=str.replace("px","");  top=str;  }  }  /*fied ie6 css hack*/  if(isIE6){  if (top>=0)  {  wrap=$("<div style=\"top:e­xpression(documentElement.scrollTop+"+top+");\"></div>");  }else{  wrap=$("<div style=\"top:e­xpression(documentElement.scrollTop+documentElement.clientHeight-this.offsetHeight);\"></div>");  }  }  $("body").append(wrap);  wrap.css(loc).css({position:"fixed",  z_index:"999"});  if (isIE6)  {  wrap.css("position","absolute");  //没有加这个的话,ie6使用表达式时就会发现跳动现象  //至于为什么要加这个,还有为什么要加nothing.txt这个,偶也不知道,希望知道的同学可以告诉我  $("body").css("background-attachment","fixed").css("background-image","url(n1othing.txt)");  }  //将要固定的层添加到固定层里  $(this).appendTo(wrap);  });  
}; 


下载地址:http://files.cnblogs.com/regedit/jquery.floatdiv.rar

这篇关于jquery插件任意位置浮动固定层的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/982887

相关文章

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文

python3如何找到字典的下标index、获取list中指定元素的位置索引

《python3如何找到字典的下标index、获取list中指定元素的位置索引》:本文主要介绍python3如何找到字典的下标index、获取list中指定元素的位置索引问题,具有很好的参考价值,... 目录enumerate()找到字典的下标 index获取list中指定元素的位置索引总结enumerat

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

HTML5 中的<button>标签用法和特征

《HTML5中的<button>标签用法和特征》在HTML5中,button标签用于定义一个可点击的按钮,它是创建交互式网页的重要元素之一,本文将深入解析HTML5中的button标签,详细介绍其属... 目录引言<button> 标签的基本用法<button> 标签的属性typevaluedisabled

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.