隐藏弹出式插件

时间:2017-08-16 09:31:40

标签: javascript jquery

我正在使用Reveal jQuery插件。 http://www.zurb.com/playground/reveal-modal-plugin

如何设置自动隐藏,例如在5秒内?

我发现此代码更多它不起作用,我不知道在哪个文件中包含它:how to auto hide jquery reveal plugin

/*
 * jQuery Reveal Plugin 1.0
 * www.ZURB.com
 * Copyright 2010, ZURB
 * Free to use under the MIT license.
 * http://www.opensource.org/licenses/mit-license.php
*/


(function($) {

/*---------------------------
 Defaults for Reveal
----------------------------*/
	 
/*---------------------------
 Listener for data-reveal-id attributes
----------------------------*/

	// $('a[data-reveal-id]').live('click', function(e) {
	// 	e.preventDefault();
	// 	var modalLocation = $(this).attr('data-reveal-id');
	// 	$('#'+modalLocation).reveal($(this).data());
	// });

	$(document).on('click', 'a[data-reveal-id]', function(e) {
		e.preventDefault();
		var modalLocation = $(this).attr('data-reveal-id');
		$('#'+modalLocation).reveal($(this).data());
	});

/*---------------------------
 Extend and Execute
----------------------------*/

    $.fn.reveal = function(options) {
        
        
        var defaults = {  
	    	animation: 'fadeAndPop', //fade, fadeAndPop, none
		    animationspeed: 300, //how fast animtions are
		    closeonbackgroundclick: true, //if you click background will modal close?
		    dismissmodalclass: 'close-reveal-modal' //the class of a button or element that will close an open modal
    	}; 
    	
        //Extend dem' options
        var options = $.extend({}, defaults, options); 
	
        return this.each(function() {
        
/*---------------------------
 Global Variables
----------------------------*/
        	var modal = $(this),
        		topMeasure  = parseInt(modal.css('top')),
				topOffset = modal.height() + topMeasure,
          		locked = false,
				modalBG = $('.reveal-modal-bg');

/*---------------------------
 Create Modal BG
----------------------------*/
			if(modalBG.length == 0) {
				modalBG = $('<div class="reveal-modal-bg" />').insertAfter(modal);
			}		    
     
/*---------------------------
 Open & Close Animations
----------------------------*/
			//Entrance Animations
			modal.bind('reveal:open', function () {
			  modalBG.unbind('click.modalEvent');
				$('.' + options.dismissmodalclass).unbind('click.modalEvent');
				if(!locked) {
					lockModal();
					if(options.animation == "fadeAndPop") {
						modal.css({'top': $(document).scrollTop()-topOffset, 'opacity' : 0, 'visibility' : 'visible'});
						modalBG.fadeIn(options.animationspeed/2);
						modal.delay(options.animationspeed/2).animate({
							"top": $(document).scrollTop()+topMeasure + 'px',
							"opacity" : 1
						}, options.animationspeed,unlockModal());					
					}
					if(options.animation == "fade") {
						modal.css({'opacity' : 0, 'visibility' : 'visible', 'top': $(document).scrollTop()+topMeasure});
						modalBG.fadeIn(options.animationspeed/2);
						modal.delay(options.animationspeed/2).animate({
							"opacity" : 1
						}, options.animationspeed,unlockModal());					
					} 
					if(options.animation == "none") {
						modal.css({'visibility' : 'visible', 'top':$(document).scrollTop()+topMeasure});
						modalBG.css({"display":"block"});	
						unlockModal()				
					}
				}
				modal.unbind('reveal:open');
			}); 	

			//Closing Animation
			modal.bind('reveal:close', function () {
			  if(!locked) {
					lockModal();
					if(options.animation == "fadeAndPop") {
						modalBG.delay(options.animationspeed).fadeOut(options.animationspeed);
						modal.animate({
							"top":  $(document).scrollTop()-topOffset + 'px',
							"opacity" : 0
						}, options.animationspeed/2, function() {
							modal.css({'top':topMeasure, 'opacity' : 1, 'visibility' : 'hidden'});
							unlockModal();
						});					
					}  	
					if(options.animation == "fade") {
						modalBG.delay(options.animationspeed).fadeOut(options.animationspeed);
						modal.animate({
							"opacity" : 0
						}, options.animationspeed, function() {
							modal.css({'opacity' : 1, 'visibility' : 'hidden', 'top' : topMeasure});
							unlockModal();
						});					
					}  	
					if(options.animation == "none") {
						modal.css({'visibility' : 'hidden', 'top' : topMeasure});
						modalBG.css({'display' : 'none'});	
					}		
				}
				modal.unbind('reveal:close');
			});     
   	
/*---------------------------
 Open and add Closing Listeners
----------------------------*/
        	//Open Modal Immediately
    	modal.trigger('reveal:open')
			
			//Close Modal Listeners
			var closeButton = $('.' + options.dismissmodalclass).bind('click.modalEvent', function () {
			  modal.trigger('reveal:close')
			});
			
			if(options.closeonbackgroundclick) {
				modalBG.css({"cursor":"pointer"})
				modalBG.bind('click.modalEvent', function () {
				  modal.trigger('reveal:close')
				});
			}
			//$('body').keyup(function(e) {
        		//if(e.which===27){ modal.trigger('reveal:close'); } // 27 is the keycode for the Escape key
			//});
			
			
/*---------------------------
 Animations Locks
----------------------------*/
			function unlockModal() { 
				locked = false;
			}
			function lockModal() {
				locked = true;
			}	
			
        });//each call
    }//orbit plugin call
})(jQuery);
        

谢谢

1 个答案:

答案 0 :(得分:0)

您可以在答案how to auto hide jquery reveal plugin

中添加以下代码
$('.button').on('click', function(){
  $('#myModal').reveal();
  delayedHideModal('#myModal', 5)
});

function delayedHideModal(selector, sec){
  setTimeout(function(){ $(selector).trigger('reveal:close'); }, sec*1000)
}

在您调用Reveal插件的js文件中添加此代码。你可以使用任何其他选择器而不是button类来点击你打开Reveal插件。该示例使用setTimeout触发reveal:close事件处理程序.Here #myModal是您要在Reveal插件中打开的选择器。

用法:创建一个HTML文件(例如test.html)或任何其他要包含javascript文件的HTML文件

<html>
<head>
<!-- Add jquery file as dependency of reveal.js-->
<script src="jquery.min.js"></script>
<!-- Add reveal plugin -->
<script src="jquery.reveal.js"></script>
<script>
$(document).ready(function(){

function delayedHideModal(selector, sec){
  setTimeout(function(){ $(selector).trigger('reveal:close'); }, sec*1000)
}

$('.button').on('click', function(){
  $('#myModal').reveal();
  delayedHideModal('#myModal', 5);
});

});
</script>
</head>
<body>
<div id="myModal">
this is inside reveal
</div> <br/> <br>
<button class="button">Click here to reveal</button>
</body>
</html>