Solved

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

Posted on 2013-06-17
8
325 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
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
8 Comments
 
LVL 53

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
Learn by Doing. Anytime. Anywhere.

Do you like to learn by doing?
Our labs and exercises give you the chance to do just that: Learn by performing actions on real environments.

Hands-on, scenario-based labs give you experience on real environments provided by us so you don't have to worry about breaking anything.

 
LVL 53

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 53

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 53

Expert Comment

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

Featured Post

Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

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

This article demonstrates how to create a simple responsive confirmation dialog with Ok and Cancel buttons using HTML, CSS, jQuery and Promises
The article shows the basic steps of integrating an HTML theme template into an ASP.NET MVC project
In this tutorial viewers will learn how to style elements, such a divs, with a "drop shadow" effect using the CSS box-shadow property Start with a normal styled element, such as a div.: In the element's style, type the box shadow property: "box-shad…
In this tutorial viewers will learn how to embed an audio file in a webpage using HTML5. Ensure your DOCTYPE declaration is set to HTML5: : The declaration should display (CODE) HTML5 is supported by the most recent versions of all major browsers…

717 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