`

html可以移动的浮动窗口

阅读更多

先看例子:

http://182.92.97.72/float_suspend/


效果描述:

(1) 鼠标点击" "即可拖动;

(2)滚动网页的竖直滚动条时,该窗口的位置固定不变;

(3)无论怎么移动,该窗口不会跑到网页可视范围之外

 

关键code:

// 拖拽效果
	function drag(){
		var tags = arguments;
		// alert(tags[0].length);//长度为4
		
		for(var i=0;i<tags[0].length;i++){
			// addEvent(tags[0].get(i),'mousedown',function(e){
				$(tags[0].get(i)).bind('mousedown',function(e){
				if(trim(this.innerHTML).length == 0) e.preventDefault();
				var _this = this;
				// var diffX = e.clientX - _this.offsetLeft;
				// var diffY = e.clientY - _this.offsetTop;

				var diffX = e.clientX - $(_this).parent().get(0).offsetLeft;
				var diffY = e.clientY - $(_this).parent().get(0).offsetTop;


				//自定义拖拽区域
				var flag = false;				
				for (var i = 0; i < tags[0].length; i ++) {
					if (e.target == tags[0].get(i)) {
						flag = true;					//只要有一个是true,就立刻返回
						break;
					}
				}


				if (flag) {
					$(document).bind('mousemove',move);
					$(document).bind('mouseup',up);
				} else {
					$(document).unbind('mousemove',move);
					$(document).unbind('mousemove',up);
				}
			
			function move(e) {
	
				$('div.suspend').css("position", 'absolute');//保证移动div的标题时,div跟着移动
				scrollTop22=document.body.scrollTop;
				if(isIEtest && scrollTop22==0){//IE中
					scrollTop22=document.documentElement.scrollTop;
				}
				//alert();
				var left = e.clientX - diffX;
				var old_top = e.clientY - diffY;
				var top=old_top+scrollTop22;
				//console.log(old_top+"\t"+scrollTop22);	
				var divWidth22=$(_this).parent().get(0).offsetWidth;//div 的宽度
				var screenWidth=document.body.clientWidth;//屏幕宽度,不兼容IE
				if(isIEtest ){//IE中,isIEtest的初始化在common_util.js 中
					screenWidth=document.documentElement.clientWidth;//屏幕宽度
				}
				//console.log(left+"\t"+screenWidth);
				var rightZero=(screenWidth-divWidth22)-left;
				if(rightZero<0)//防止div跑到窗口的右边之外
				{
					left+=rightZero;
				}
				if (left < 0) {
					left = 0;
				}else if(left <= getScroll().left){
					left = getScroll().left;
				} else if (left > getInner().width + getScroll().left - $(_this).parent().get(0).offsetWidth) {
					left = getInner().width + getScroll().left- $(_this).parent().get(0).offsetWidth;
				}
				
				if (top < 0) {
					top = 0;
				}else if(top <= getScroll().top){
					top = getScroll().top
				} else if (top > getInner().height + getScroll().top - $(_this).parent().get(0).offsetHeight) {
					top = getInner().height + getScroll().top - $(_this).parent().get(0).offsetHeight;
				}


				$(_this).parent().get(0).style.left = left + 'px';
				$(_this).parent().get(0).style.top = top + 'px';
				//$(_this).parent().get(0).style.bottom= (50+old_top)+ 'px';
				if (typeof _this.setCapture != 'undefined') {
					_this.setCapture();
				} 
			}
			
			function up(e) {
				$('div.suspend').css("position", 'fixed');//保证上下移动滚动条时div保持不变,所以必须恢复为fixed
				var event_clientY=e.clientY;
				var top =event_clientY  - diffY;
				var screenHight=document.body.clientHeight;//屏幕高度,不兼容IE
				if(isIEtest ){//IE中,isIEtest的初始化在common_util.js 中
					screenHight=document.documentElement.clientHeight;//屏幕高度
				}
				var divHeight22=$(_this).parent().get(0).offsetHeight;//div 的高度
				//console.log(event_clientY+"\t "+diffY+"\t"+screenHight+"\t"+divHeight22+"\t"+document.body.scrollTop );
				var bottomZero=screenHight-divHeight22+diffY;
				//console.log(bottomZero+"\t"+top);
				if(event_clientY>bottomZero){//防止div跑到bottom以下,防止div跑出窗口之下
					//alert(111);
					top-=(event_clientY-bottomZero);
				}
				if(top<0)//top为负数,就表示div拖拽到窗口之上了
				{
					top=0;//防止div跑出窗口之上
				}
				$(_this).parent().get(0).style.top = top + 'px';//解决鼠标松开时位置突变的不正常现象
				$(document).unbind('mousemove',move);
				$(document).unbind('mouseup',up);
				if (typeof _this.releaseCapture != 'undefined') {
					_this.releaseCapture();
				}
			}


			});
		}

 源代码见附件float_suspend.zip

参考:http://huangkunlun520.blog.51cto.com/2562772/1570707

  • 大小: 59.8 KB
  • 大小: 2.6 KB
3
1
分享到:
评论
3 楼 hw1287789687 2017-02-13  
蒙奇君杰 写道
谢谢了!挺有用的

能帮到你很开心
2 楼 蒙奇君杰 2017-02-08  
谢谢了!挺有用的

相关推荐

    QQ 在线客服 浮动窗口

    【QQ在线客服浮动窗口】是一种常见于网站或应用中的交互设计,它允许用户在使用其他功能的同时方便地与客服人员进行沟通。QQ作为中国最流行的即时通讯工具之一,其在线客服系统被广泛应用于各类企业网站,为用户提供...

    Jquery插件之浮动窗口(DIV)

    最后,为了让浮动窗口可以关闭,我们需要添加一个关闭按钮,并监听其点击事件: ```javascript $('#closeBtn').click(function() { $floatWin.slideUp(); // 使用jQuery的slideUp方法淡出隐藏 }); ``` 为了方便...

    浮动窗口

    浮动窗口在IT行业中通常指的是那些在用户界面中可以自由移动、不会被其他元素遮挡的窗口组件,常见于各种软件和网页设计中。这种技术在实现动态广告、通知提示、设置面板等方面非常实用。在本篇文章中,我们将深入...

    js弹出可移动可关闭浮动窗口并灰化背景

    在JavaScript(简称JS)编程中,创建一个可移动、可关闭且带有灰化背景的浮动窗口是一项常见的需求,尤其在用户交互和提示信息显示时。这个功能可以使用户聚焦于特定的对话框,同时防止他们在处理关键操作时被其他...

    jQuery可拖动右下角浮动窗口特效.zip

    本项目“jQuery可拖动右下角浮动窗口特效”就是基于jQuery实现的一种用户界面交互功能,旨在提供一个可自由移动且能自适应浏览器窗口大小的浮动窗口。这种效果常见于弹出提示框、广告浮窗或设置面板,能够提升用户的...

    jQuery版简单易用的可拖动右下角浮动窗口.zip

    1. HTML结构:创建浮动窗口的HTML元素,可能包括一个包含内容的容器和一个作为拖动手柄的部分。 2. CSS样式:定义窗口的外观,包括大小、颜色、边框等,以及`fixed`定位确保其浮动效果。 3. JavaScript/jQuery代码:...

    jquery右下角浮动窗口.zip

    7. **响应式设计**:考虑到不同设备和屏幕尺寸,开发者可能还需要考虑浮动窗口的响应式设计,以适应移动设备和桌面浏览器,这需要对CSS媒体查询(Media Queries)有了解。 综上所述,"jquery右下角浮动窗口"项目...

    可拖动的JS浮动窗口类(调用方便)

    5. **类(Class)的使用**:为了实现代码的复用性和可维护性,我们可以使用JavaScript的类(ES6中的`class`关键字)来封装浮动窗口的创建和拖动逻辑。这样,每次需要创建新的浮动窗口时,只需实例化这个类,并传入...

    JSP 可拖拽浮动窗口

    **浮动物件技术详解——基于JavaScript的JSP可拖拽浮动窗口** 在Web开发中,为了提供更加丰富和交互式的用户体验,我们常常需要创建能够浮动并可自由拖拽的窗口。这种技术通常被称为浮动物件(Floating Widget)或...

    网页浮动广告窗口

    网页浮动广告窗口是一种常见的网页设计技术,用于在用户浏览页面时始终显示特定的广告或信息。这种技术通过JavaScript实现,可以将广告放置在屏幕的右侧或左侧,甚至可以设置为固定位置,使得无论用户滚动页面,广告...

    页面中的浮动窗口.doc

    在网页设计中,浮动窗口是一种常见的广告或交互元素呈现方式,它可以随着用户滚动页面而保持在屏幕的特定位置,提供持续的视觉效果或功能。在给出的文档中,提到了三种类型的浮动窗口:左栏浮动广告、右栏浮动广告...

    浮动登录窗口和窗口移动

    在实际应用中,浮动登录窗口和窗口移动的结合可以提供更灵活的用户体验。例如,用户可以将登录窗口放置在屏幕的任何角落,以便于输入账号信息。同时,如果登录窗口设计为透明或半透明,那么用户在登录时仍能保持对...

    仿阿里妈妈的右下角浮动窗口

    在IT行业中,创建一个仿阿里妈妈的右下角浮动窗口是一项常见...通过上述步骤,我们可以构建一个类似阿里妈妈的右下角浮动窗口。这不仅提升了网站的互动性,也能有效地传达信息给用户,是一个实用且常见的前端开发实践。

    javascript实现可以拖动的浮动窗口;源代码

    在这个场景中,我们关注的是使用JavaScript来实现一个可以拖动的浮动窗口功能。这种技术常用于创建更加交互性和用户友好的网页元素,如对话框、通知或者自定义控件。 实现拖动功能的关键在于监听用户的鼠标事件,...

    jQuery页面右下角浮动窗口代码.zip

    通过结合这些基础知识,我们可以创建出一个功能丰富的浮动窗口,为用户提供更佳的交互体验。实践过程中,需要注意代码的模块化和可维护性,以便在未来进行扩展或修改。同时,良好的文档和注释也是提高代码质量的重要...

    jQuery右击logo弹出浮动窗口.zip

    4. **浮动窗口**:浮动窗口通常是网页上的一个可移动、半透明或具有特定样式的元素,它可以在页面上的任何位置显示。在jQuery中,可以使用CSS样式和JavaScript来控制这个元素的位置和行为。 5. **DOM操作**:jQuery...

    JS右下角弹出可滚动的新闻列表浮动窗口

    2. **浮动窗口**:浮动窗口是网页设计中的一个概念,它是指那些在页面上固定位置,即使页面滚动也不会移动的元素。通常通过CSS的`position`属性设置为`fixed`来实现,然后通过`top`和`right`属性调整其在屏幕上的...

    新浪奥运频道的Js右下角浮动窗口代码打包

    在网页设计中,右下角浮动窗口通常用于显示广告、通知或者重要的消息提示,这种设计可以吸引用户的注意力,同时不影响主要内容的浏览。实现这样的效果,开发者通常会用到JavaScript的DOM(Document Object Model)...

    jQuery版简单易用的可拖动右下角浮动窗口特效.zip

    《jQuery版简单易用的可拖动右下角浮动窗口特效》 在现代网页开发中,用户界面的交互性越来越受到重视,一个优秀的交互设计能够提升用户体验,使网站或应用更具吸引力。本教程将深入探讨如何利用jQuery实现一个简单...

Global site tag (gtag.js) - Google Analytics