Solved

Decrease div width from 100% to 0% in ten seconds

Posted on 2013-06-17
8
320 Views
Last Modified: 2013-06-19
Hi,

I need to make a time indicated decrease bar. The bar's width must decrease from 100% to 0% width in 10 seconds.

How could i do that?

Thanks!
0
Comment
Question by:peps03
8 Comments
 
LVL 52

Accepted Solution

by:
Scott Fell,  EE MVE earned 375 total points
ID: 39254790
Working sample http://jsbin.com/obeyob/1/edit
code
<!DOCTYPE html>
<html>
<head>
  <style>
    #container
    {
      width:500px;
      border:thin;
      border-color:black;
      border-style:solid;
      
    }
#bar
    {
      width:500px;
      height:30px;
      background-color:red;
}
</style>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.1/jquery.min.js"></script>
<meta charset=utf-8 />
<title>JS Bin</title>
</head>
<body>
 
<button id="go">&raquo; Start</button>
<div id="container"> 
    <div id="bar"></div>
</div>  
<script>
 

 
$("#go").click(function(){
  $("#bar").animate({
    width: "0%",
   
  }, 10000 );
});
</script>
</body>
</html>

Open in new window

0
 

Author Comment

by:peps03
ID: 39256229
Thanks!

i put the code in this function:

			$(function() {
				refreshContent(); // Call refreshContent immediately
				setInterval('refreshContent()',10000);
			});
			
			function refreshContent()
			{
				$('.bar').width("100%");
			        $(".bar").animate({width: "0",}, 10000 );	
				$.post('testemonial-content.php',{}, function(resp) {
					$('div.cycle.contentleft:hidden').html(resp.left);
					$('div.cycle.contentright:hidden').html(resp.right);
					$('div.cycle').fadeToggle(0);
				},'json');
				
			}

Open in new window


and it sort of works as expected, for the first 2 rounds. after the content has switched twice, the bar doesn't run anymore.

Why does it stop running?
0
 
LVL 53

Expert Comment

by:COBOLdinosaur
ID: 39256597
In modern browsers you do it with the CSS:

.bar {
             width:100%;
         }
.barActive {
                     width:0px;
                      transition:width 10s ease-out;
                  }
Then all you need is an event to change the className from 'bar' to 'barActive'.

Cd&
0
Master Your Team's Linux and Cloud Stack!

The average business loses $13.5M per year to ineffective training (per 1,000 employees). Keep ahead of the competition and combine in-person quality with online cost and flexibility by training with Linux Academy.

 
LVL 52

Expert Comment

by:Scott Fell, EE MVE
ID: 39256827
I like that ease of use without js.  I have not fully embraced it yet because I enjoy making things overly complex for myself and get satisfaction from making it work.

Just add, "-webkit-transition:width 10s ease-out;" so it works with safari.  

If you are looking to do some type of timer that starts when an action happens like answering a test question, you will need to use javascript/jquery.
0
 
LVL 52

Expert Comment

by:Scott Fell, EE MVE
ID: 39256839
>Why does it stop running?
Will you please edit the jsbin I created with just the important code and lets take a look.

Even better, please post the link to your sample page.
0
 
LVL 19

Assisted Solution

by:Albert Van Halen
Albert Van Halen earned 125 total points
ID: 39257545
The 10 second interval occurs just a bit earlier than the animation is complete.
In order to have it working you have to stop the animation using the stop method.
$('.bar').stop().width("100%");

Open in new window

0
 

Author Closing Comment

by:peps03
ID: 39258645
@padas, thanks for the code, great!

@AlbertVanHalen, thanks!! This works!!
0
 
LVL 52

Expert Comment

by:Scott Fell, EE MVE
ID: 39258731
Thanks for the points
0

Featured Post

Webinar: Aligning, Automating, Winning

Join Dan Russo, Senior Manager of Operations Intelligence, for an in-depth discussion on how Dealertrack, leading provider of integrated digital solutions for the automotive industry, transformed their DevOps processes to increase collaboration and move with greater velocity.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

This article describes how to create custom column layout styles for Bootstrap. The article uses 5 columns to illustrate the concept, but the principle can be extended to any number of columns.
Not sure what the best email signature size is? Are you worried about email signature image size? Follow this best practice guide.
In this tutorial viewers will learn how to style different bullet points for unordered lists in CSS. Begin with a normal unordered list; the default bullet point is a solid circle: In the CSS, create a defined class of unordered list by typing "ul.S…
The viewer will learn the basics of jQuery including how to code hide show and toggles. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery…

789 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question