`
qesc
  • 浏览: 1291 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
文章分类
社区版块
存档分类

尝试一下写的一个JQuery插件:给任意触发物件加上弹出任意对象渐显动画效果

阅读更多
做项目时想省事儿写的一个JQ插件,新手练习,敬请拍砖斧正。

简介:给一个对象绑定点击函数,可以动画居中渐显弹出任意一个别的对象(当然是在当前页面中的,是否隐藏无所谓)。点击后弹出遮罩和对象,关闭后的DOM结构与点击前一样,释放所有资源。可任意绑定多个对象。

代码中亦有注解,有演示文件附件下载。

;(function(){
 /*
	说明:
	给任意触发物件加上弹出任意对象渐显动画效果,弹出位置为物件原始位置,自动遮罩,自动渐显,自动屏幕居中。宽高和时间可控。
	一般用作图片显示,如有其它用途,简单修改即可,理论上兼容所有浏览器,硬盘和内存占用均较低
	
	参数:
	triggerId  触发点ID,没有则返回
	resourcId  原始资源ID
	popW  弹出后的宽,默认为图片显示宽
	popH  弹出后的高,默认为图片显示高
	dure  弹出时间, 默认为1000毫秒
	closeId  关闭对象的ID,默认为关闭按钮


	DEMO:
	$.fadeOutDiv('pictureId', 'pictureId', 200, 200, 'fast');
	$.fadeOutDiv('triggerId', 'pictureId', 640, 480, 'slow', 'popup_div');
*/

	// 如果之前没有引用jQuery则弹出提示并退出
	if ( window.jQuery ){

		jQuery.extend({
			fadeOutDiv: function(triggerId, srcId, popW, popH, dure, closeId){

				if( !document.getElementById(triggerId) || !document.getElementById(srcId)){return false;}


	/* 可修改参数区域:如必要,可根据具体情况自行修改 */
				var maskId = 'div_bgmask';		// 遮罩层ID
				var popupBgId = 'popup_bgdiv';	// 弹出层ID
				var popupCntId = 'popup_cnt';	// 弹出层中容器ID
				var popupImgId = 'popup_img';	// 弹出层中图片ID
				var popupDivId = 'popup_div';	// 弹出层中DIV的ID
				var popupBorderW = 23;			// 弹出层的边框宽度(双边)
				var popupBorderH = 31;			// 弹出层的边框高度(双边)
				var btnCloseId = 'btn_close';	// 弹出层关闭按钮ID
				var zindex = 499;				// 弹出层的Z-index


				// 遮罩层语句
				var bgmask = '<div id="'+ maskId +'" class="plugin_fadeoutdiv_mask" style="display:none"></div>';
				// 弹出层语句
				var divpopup = '<div class="plugin_fadeoutdiv" id="'+ popupBgId +'" style="position:absolute;display:none;"><span><b id="'+ btnCloseId +'">&nbsp;</b><div class="clear"></div><div id="'+ popupCntId +'"><img id="'+ popupImgId +'" src="" /></div></span></div>';
	/*可修改参数区域结束*/


				var navW = document.documentElement.clientWidth;	// 浏览器可见区域宽
				var navH = document.documentElement.clientHeight;	// 浏览器可见区域高
				var srcW = document.getElementById(srcId).offsetWidth;	// 弹出物件的原始宽
				var srcH = document.getElementById(srcId).offsetHeight;	// 弹出物件的原始高
				var tigW = document.getElementById(triggerId).offsetWidth;	// 触发物件的原始宽
				var tigH = document.getElementById(triggerId).offsetHeight;	// 触发物件的原始高
				var tigT, tigL;	// 触发物件的原始相对位置

				var popW = popW || srcW;
				var popH = popH || srcH;
				var dure = dure || 1000;
				var closeId = closeId || btnCloseId;


				// 弹出层动画效果显示函数
				var animaShowPopup = function(){

					$('body').append(bgmask).append(divpopup);
					document.getElementById(maskId).style.zIndex = zindex;
					document.getElementById(popupBgId).style.zIndex = zindex;
				

					// 得到浮动元素相对整个页面的TOP和LEFT
					(function(){
						var obj = document.getElementById(triggerId);
						tigT = obj.offsetTop;	tigL = obj.offsetLeft;
						
						while( obj = obj.offsetParent ){
							 tigT += obj.offsetTop;	tigL += obj.offsetLeft;
						 }
					})();
					var scrolTop = document.documentElement.scrollTop;	// 当前滚动条上卷距离
					var bgW = document.body.scrollWidth;		// 得到全页面宽
					var bgH = document.body.scrollHeight;		// 得到全页面高

					$('#'+maskId).width(bgW).height(bgH).show();
					$('#'+popupCntId).addClass('plugin_fadeoutdiv_cnt');
					var tagSrc = (document.getElementById(srcId).tagName).toLowerCase();


					switch(tagSrc){
						case	'object':	// object对象或应单独处理
							break;
						case	'img':		// 弹出对象为图片
							var conteSrc = $('#'+srcId).attr('src') || '';	// 得到图片原始文件路径
							$('#'+popupImgId).attr('src',conteSrc).css({width:tigW, height:tigH});
							var act = popupImgId;
							break;
						case	'div':		// 默认弹出对象为DIV
						default:
							$('#'+srcId).clone().replaceAll('#'+popupImgId).attr('id', popupDivId).css({border:'none'}).addClass('plugin_fadeoutdiv_div');
							var act = popupDivId;
							break;
					}// end switch
					$('#'+popupBgId).css({top:tigT-popupBorderH/2,left:tigL-popupBorderW/2}).animate({top:(navH-popH-popupBorderH)/2+scrolTop,left:(navW-popW-popupBorderW)/2, opacity:'show' }, dure);
					$('#'+act).animate({width:popW, height:popH }, dure );					


					
					// 弹出浮动层动画效果隐藏函数
					var animaHidePopup = function(){
						switch(tagSrc){
							case	'img':		// 弹出对象为图片
								var act = popupImgId;
								break;

							case	'div':
							case	'object':	// object对象或应单独处理?
							default:		// 默认弹出对象为DIV
								var act = popupDivId;
							break;
						}// end switch
						$('#'+popupBgId).animate({top:tigT-popupBorderH/2, left:tigL-popupBorderW/2, opacity:'hide' }, dure);
						$('#'+act).animate({width:tigW, height:tigH }, dure,
							function(){	$('#'+maskId).remove();	$('#'+popupBgId).remove();
						});
					};// end function animaHidePopup
					$('#'+closeId).css({'cursor':'pointer'}).click(animaHidePopup);

				};// end function animaShowPopup
				$('#'+triggerId).css({'cursor':'pointer'}).click(animaShowPopup);

			}// end function fadeoutdiv
		});

	} else {	// 未加载jQuery

		alert('Lib jQuery not included !!!');
		return false;

	}



// end jQuery fadeOutDiv Plugin
})();
分享到:
评论
8 楼 riasky 2010-05-25  
IE6下的<select>问题没有考虑?
7 楼 qesc 2010-04-06  
;(function($){

 /*
	说明:
	给任意物件绑定点击函数,点击后弹出任意对象渐显动画效果,弹出位置为物件原始位置,自动遮罩,自动渐显,自动屏幕居中,宽高和时间可控。关闭后自动清除所用资源。
	一般用作图片显示,如有其它用途,简单修改即可

	特点:
	理论上兼容所有浏览器,硬盘和内存占用均较低
	
	参数:
	trigerId	触发对象ID,必须存在
	showerId	渐显对象ID,默认为触发对象
	closerId	控制关闭的对象ID
	showW		显示宽度,默认为触发对象宽度
	showH		显示高度,默认为触发对象高度
	dure		动画持续时间, 默认为普通模式
	zindex		弹出层的z-index值,默认为499
	bgColor		遮罩层背景色,默认为黑色
	bgOpac		遮罩层透明度,默认为0.7
	其他参数一般不用改,除非与页面中的标签ID产生冲突
	遮罩层和弹出层定义也都开放,如需要可自行定义


	DEMO:
	$.fadeOutDiv({trigerId:'pictureId',});
	$.fadeOutDiv({trigerId:'pictureId', showW:200, showH:200, dure:'fast'});
	$.fadeOutDiv({trigerId:'trigerId', showerId:'pictureId', shouW:640, showH:480, dure:'slow', closerId:'popup_cnt'});
*/

	if ( window.jQuery ){

		$.extend({
			fadeOutDiv: function(options){

				var df = {     
					trigerId: null,			// 触发对象	
					showerId: null,			// 显示对象
					closerId: null,			// 触发关闭的对象
					showW	: null,			// 显示宽度
					showH	: null,			// 显示高度
					dure	: 'normal',		// 动画持续时间
					zindex	: 499,			// 弹出层的z-index
					bgColor	: 'black',		// 遮罩背景色
					bgOpac	: '0.7',		// 遮罩透明度

					popupMaskId	: 'div_bgmask',		// 遮罩层ID
					popupBgId	: 'popup_bgdiv',	// 弹出层ID
					popupCntId	: 'popup_cnt',	// 弹出层中容器ID
					popupImgId	: 'popup_img',	// 弹出层中图片ID
					popupDivId	: 'popup_div',	// 弹出层中DIV的ID
					popupBtnId	: 'popup_btn',	// 弹出层中关闭按钮ID
					popupBorderW: 23,			// 弹出层的边框宽度(双边)
					popupBorderH: 31,			// 弹出层的边框高度(双边)
					bgmask:	null,		// 遮罩层语句
					divpopup:null		// 弹出层语句

				};     
				// 输入的参数覆盖默认值     
				$.extend(df, options);

				// 触发对象不存在则退出
				if( !document.getElementById(df.trigerId) ){return false;}
				// 显示对象如不存在,则修正为触发对象
				if( !document.getElementById(df.showerId) ){df.showerId = df.trigerId;}
				// 遮罩层语句处理
				df.bgmask	= df.bgmask || '<div id="'+ df.popupMaskId +'" class="plugin_fadeoutdiv_mask" style="display:none"></div>';
				// 弹出层语句处理
				df.divpopup	= df.divpopup || '<div class="plugin_fadeoutdiv" id="'+ df.popupBgId +'" style="position:absolute;display:none;"><span><b id="'+ df.popupBtnId +'">&nbsp;</b><div class="clear"></div><div id="'+ df.popupCntId +'"><img id="'+ df.popupImgId +'" src="" /></div></span></div>';


				var navW = document.documentElement.clientWidth;	// 浏览器可见区域宽
				var navH = document.documentElement.clientHeight;	// 浏览器可见区域高

				var tigW = document.getElementById(df.trigerId).offsetWidth;	// 触发物件的原始宽
				var tigH = document.getElementById(df.trigerId).offsetHeight;	// 触发物件的原始高
				var srcW = document.getElementById(df.showerId).offsetWidth;	// 弹出物件的原始宽
				var srcH = document.getElementById(df.showerId).offsetHeight;	// 弹出物件的原始高
				var tigT, tigL;	// 触发物件的原始相对位置

				var popW = df.showW || srcW;
				var popH = df.showH || srcH;


				// 浮动层动画效果显示函数
				var animaShowPopup = function(){

					$('body').append(df.bgmask).append(df.divpopup);
					document.getElementById(df.popupMaskId).style.zIndex = df.zindex;
					document.getElementById(df.popupBgId).style.zIndex = df.zindex;
				

					// 动态得到触发对象相对整个页面的TOP和LEFT
					(function(){
						var obj = document.getElementById(df.trigerId);
						tigT = obj.offsetTop;	tigL = obj.offsetLeft;
						
						while( obj = obj.offsetParent ){
							 tigT += obj.offsetTop;	tigL += obj.offsetLeft;
						 }
					})();

					var scrolTop = document.documentElement.scrollTop;	// 当前滚动条上卷距离
					var bgW = document.body.scrollWidth;		// 得到全页面宽
					var bgH = document.body.scrollHeight;		// 得到全页面高


					$('#'+df.popupMaskId).css({width:bgW, height:bgH, background:df.bgColor, opacity:df.bgOpac}).show();
					$('#'+df.popupCntId).addClass('plugin_fadeoutdiv_cnt');
					var tagSrc = (document.getElementById(df.showerId).tagName).toLowerCase();


					switch(tagSrc){
						case	'img':		// 弹出对象为图片
							var conteSrc = $('#'+df.showerId).attr('src') || '';	// 得到图片原始文件路径
							$('#'+df.popupImgId).attr('src',conteSrc).css({width:tigW, height:tigH});
							var act = df.popupImgId;
							break;
						case	'object':	// object对象或应单独处理?
						case	'div':		// 默认弹出对象为div
						default:
							$('#'+df.showerId).clone().replaceAll('#'+df.popupImgId).attr('id', df.popupDivId).css({border:'none'}).addClass('plugin_fadeoutdiv_div');
							var act = df.popupDivId;
							break;
					}// end switch

					$('#'+df.popupBgId).css({top:tigT-df.popupBorderH/2,left:tigL-df.popupBorderW/2}).animate({top:(navH-popH-df.popupBorderH)/2+scrolTop,left:(navW-popW-df.popupBorderW)/2, opacity:'show' }, df.dure);
					$('#'+act).animate({width:popW, height:popH }, df.dure);					


					
					// 浮动层动画效果隐藏函数
					var animaHidePopup = function(){

						switch(tagSrc){
							case	'img':		// 弹出对象为图片
								var act = df.popupImgId;
								break;
							case	'object':	// object对象或应单独处理?
							case	'div':
							default:		// 默认弹出对象为DIV
								var act = df.popupDivId;
							break;
						}// end switch

						$('#'+df.popupBgId).animate({top:tigT-df.popupBorderH/2, left:tigL-df.popupBorderW/2, opacity:'hide' }, df.dure);
						$('#'+act).animate({width:tigW, height:tigH }, df.dure,
							function(){	$('#'+df.popupMaskId).remove();	$('#'+df.popupBgId).remove();} );
					};// end function animaHidePopup
					// 关闭对象如不存在,则自动修正为按钮关闭
					if( !document.getElementById(df.closerId) ){df.closerId = df.popupBtnId;}
					$('#'+df.closerId).css({'cursor':'pointer'}).click(animaHidePopup);

				};// end function animaShowPopup
				$('#'+df.trigerId).css({'cursor':'pointer'}).click(animaShowPopup);

			}// end function fadeoutdiv
		});

	} else {	// 未加载jQuery则警示退出

		alert('Lib jQuery not included !!!');
		return false;

	}



// end jQuery fadeOutDiv Plugin
})(jQuery);
6 楼 qesc 2010-04-06  
新修改完毕,现在所有参数都可由使用者定义传参使用,如果大家觉得哪个参数也可以提出来,敬请提出。

目前也发现了一些问题:
1.遮罩层透明度开放后,由本来的CSS固定定义变为使用者传参,在OP下JQ的设置无效,只能认出默认值。无法解决。
2.当图片放大后如果宽高大于当前页面,背景的遮罩需要resize。未解决。
3.图片链接为非本地时,有可能出现取不到原图片宽高的bug。未解决。
5 楼 wing5jface 2010-04-06  
渐显动画效果不错,jquery载入没有使用google,速度显示如何?
在线任意对象渐显动画效果可看:http://www.hy2999.com/jquery/fadeoutdivDemo/
4 楼 qesc 2010-04-06  
,感谢各位批评指正,先行谢过!

aguai0:图片缩放之后的处理还可以做哪些操作可以修改得更好呢?不好意思没太明白,麻烦你可否详细说明下。

02221021:我用jQ的时候有时候考虑运行速度的原因会插一些JS代码,也算是一种吹毛求疵吧。不过getDocumentById,那点儿速度差不算啥,下次就改过来。

koalaxyq:jQuery本身就有内置计算宽、高的函数,是的,但是我曾经碰到过得不到数据的bug,从此留下阴影就没再用width和height这两个函数get过,只set过 ^^
设计一些可定义的参数?恩,是的,我看了“jQuery插件开发全解析”那贴以后,决定把参数全部用options的方式可以由使用者自由定义,差不多开发完毕,再测试一下就贴出来请大家拍
3 楼 koalaxyq 2010-04-02  
02221021 写道
给个建议, 既然用了jquery 就不要用document.getElementById 这些东西了


 还有就是jQuery本身就有内置计算宽、高的函数,也很省事,再有就是可以设计一些可定义的参数,那样就更灵活了。
2 楼 02221021 2010-04-02  
给个建议, 既然用了jquery 就不要用document.getElementById 这些东西了
1 楼 aguai0 2010-04-02  
不错,只是图片缩放之后的处理做些操作就更好了

相关推荐

    jQuery插件:警告-确认-提示弹出对话框效果_jquery_alert_dialogs

    jQuery插件:警告-确认-提示弹出对话框效果_jquery_alert_dialogsjQuery插件:警告-确认-提示弹出对话框效果_jquery_alert_dialogsjQuery插件:警告-确认-提示弹出对话框效果_jquery_alert_dialogs

    jQuery弹出层插件三种简单遮罩弹出框效果.rar

    《jQuery弹出层插件:实现简单遮罩弹出框效果》 在Web开发中,弹出层(Modal)是一种常见的交互元素,用于在用户与页面进行交互时提供额外的信息或者功能。jQuery作为一款强大的JavaScript库,提供了丰富的插件来...

    jQuery弹出层插件三种简单遮罩弹出框效果

    例如,通过`.fadeIn()`和`.fadeOut()`方法实现弹出框的渐显渐隐,或者使用`.slideToggle()`实现上下滑动效果。 3. **插件化的遮罩弹出框** 为了提高开发效率和代码复用性,许多开发者会编写jQuery插件来封装这些...

    jquery插件库大全(200个).zip

    jquery插件库大全(200个): jqueryQQ表情插件 jquery下拉菜单导航 jquery下拉菜单栏 jquery仿Windows系统选中图标效果 jquery仿京东商品详情页图片放大效果 jquery仿百度新闻焦点轮播 jquery分离布局模版 jquery...

    jquery弹出层插件

    jQuery插件是jQuery库的一个扩展,它们通过添加新的功能来增强原生的jQuery对象。开发者通常会将一些常见的功能封装成插件,以便于复用和提高开发效率。这个弹出层插件就是基于jQuery的,它可以无缝集成到现有的...

    jquery插件弹出div

    "jquery插件弹出div"是一个基于jQuery的插件,用于创建弹出式对话框或者模态框,通常用于显示警告、确认消息或者进行表单提交等交互操作。在网页设计中,这种功能能够提升用户体验,因为它可以将用户注意力集中在...

    jquery插件:ajax和iframe加载提示效果

    这个jQuery插件正是为了解决这个问题而设计的,它提供了一种优雅的方式来显示加载提示,以遮挡效果的方式增强用户的感知。 **插件的核心功能** 1. **Ajax请求提示**:当jQuery的$.ajax()方法被调用时,插件会自动...

    网页模板——jQuery实现滚动到网站页面底部动画弹出对话框.zip

    这个压缩包文件"网页模板——jQuery实现滚动到网站页面底部动画弹出对话框.zip"很可能是包含了一个示例或模板,用于教导开发者如何利用jQuery来创建这种动态效果。 首先,我们来详细解释一下这个功能的核心知识点:...

    20种弹出层,弹窗 jQuery+CSS3 多功能弹出层插件v2.0.1

    "20种弹出层"是一款基于jQuery和CSS3技术的弹出层插件,它集成了20种不同的弹出效果,每一种都具有独特的视觉表现和用户体验。这款插件旨在帮助开发者轻松实现各种类型的弹出层,无论是在简单的信息提示,还是复杂的...

    jquery弹出层插件SexyLightBox

    **jQuery弹出层插件SexyLightBox详解** 在网页设计中,弹出层是一种常见的交互元素,用于在用户点击某个链接或按钮时显示一个浮动窗口,通常用来展示图片、视频或者详细信息。SexyLightBox是一款基于jQuery的弹出层...

    jquery插件(网页右下角弹出窗口)

    总的来说,这个jQuery插件为网页右下角弹出窗口提供了一种简单而强大的解决方案,可以帮助开发者快速实现这一常见功能,提高网站的互动性和用户体验。通过深入理解其工作原理和配置选项,你将能够更好地定制和优化弹...

    jQuery插件集之(弹出div4)+Demo

    本资源“jQuery插件集之(弹出div4)+Demo”提供了一个实用的解决方案,即用div而非模态窗口实现弹出功能。这个插件设计巧妙,能够为用户提供一种灵活的方式来展示信息,而无需依赖于传统的模态框。 首先,让我们深入...

    jQuery插件集之(弹出div2)+Demo

    本篇文章将深入探讨一个基于jQuery的插件,标题为"jQuery插件集之(弹出div2)+Demo",该插件主要用于在页面上弹出一个div元素,而非传统的模态窗口,提供了一种轻量级且灵活的替代方案。 首先,让我们了解为什么...

    JQuery弹出层插件

    在前端开发中,jQuery弹出层插件是用于创建弹窗效果的重要工具,它能够帮助开发者轻松实现模态对话框、提示信息、加载提示等交互功能。本篇将详细介绍jQuery弹出层插件,以及如何使用名为"Popup Div"的实例。 首先...

    CSS3动画过渡的jquery动态弹出框插件_弹出框_

    本主题聚焦于利用CSS3动画过渡效果和jQuery库创建动态弹出框插件。这种结合使得弹出框不仅功能强大,还能提供平滑、吸引人的视觉体验。 首先,让我们了解CSS3中的动画和过渡。CSS3的`transition`属性允许我们在更改...

    自己写的jquery 弹出层插件,可拖动

    标题中的“自己写的jquery 弹出层插件,可拖动”表明这是一个基于jQuery的自定义弹出框插件,具备拖动功能。在Web开发中,弹出层(也称为对话框或模态窗口)常用于显示警告、确认信息或者提供用户交互界面。这个插件...

    各种jquery弹出框插件

    虽然这不是一个弹出框插件,但粒子效果可能被用于创建背景动态效果,为弹出框添加视觉吸引力。这类效果通常需要服务器环境运行,因为它们可能涉及到JavaScript动画和实时渲染。 7. **jquery分页插件**: 这个插件...

    jQuery LayerModel弹出层插件拖动弹出层效果

    jQuery LayerModel是一款基于jQuery的弹出层插件,它提供了丰富的功能,包括创建各种类型的弹出窗口,如提示、信息、确认、加载等,并且支持弹出层的拖动效果。在网页交互设计中,弹出层是常用的一种增强用户体验的...

    jquery插件库-jquery弹出层 三种弹出效果.zip

    本资源"jquery插件库-jquery弹出层 三种弹出效果.zip"聚焦于jQuery的一个特定应用:弹出层效果。下面我们将详细探讨jQuery弹出层的原理、实现方式以及三种不同的弹出效果。 1. jQuery弹出层基础 jQuery弹出层,通常...

    支持弹出图片视频jQuery插件.zip

    总结来说,"支持弹出图片视频jQuery插件.zip" 提供了一个强大的工具,可以帮助开发者快速构建交互性强、视觉效果出色的图片和视频展示功能。通过熟练掌握和应用这个插件,可以在网页设计中提升用户体验,同时减轻...

Global site tag (gtag.js) - Google Analytics