Comunidad de diseño web y desarrollo en internet online

Cambiar background-image de div que despliega otro div con toggle()

Citar            
MensajeEscrito el 15 Oct 2014 04:32 pm
Buen día, mi nombre es Edwing, y soy novato en esto del desarrollo web, he estado creando una página web que contenga un header con "position: fixed"; el caso es que quiero que cuando el usuario haga scroll hacia abajo tenga la posibilidad de esconder (o mostrar si es el caso) dicha cabecera si así lo desea, dando click sobre el área de un div que uso como "botón" el cual aparece solo a cierta cantidad de pixeles recorridos al hacer el scroll, en ese ejercicio me di cuenta que lo pertinente sería que si el usuario vuelve a arriba haciendo scroll sin hacer aparecer de nuevo la cabecera con el botón, esta (la cabecera) debía aparecer automáticamente en el instante que desaparezca el botón en el limite de pixeles establecido, es decir, que en la parte top de la página esta siempre sea visible, bueno pues todo eso ya lo logré con la función toggle(), pero se me ha ocurrido que el botón que es un div, cambie su background-image de una flecha hacia arriba a una hacia abajo o viceversa para indicar la acción que se ejecutaría si se le da click, y logré hacerlo hasta cuando escondo el header, pero cuando le vuelvo a dar click para que se despliegue de nuevo la flecha se queda sin cambiar de nuevo el background-image, y no he logrado solucionarlo, debo decir que cuando se hace automáticamente con el scroll hacia arriba SI me cambia el background-image, pero con el botón no he sido capaz (NOTA: Uso un "if" en el scpript de Jquery para intentar hacer eso) .... voy adjuntar los códigos y agradezco a quien me ayude a encontrar como solucionarlo... (NOTA 2: En el código uso un div con id="fixed-container" haciendo las veces del "header".)

Código HTML :

<!DOCTYPE html>
<html lang="es">
   <head>
      <title> Analsis Position fixed </title>
      <meta charset="utf-8" />
      <link rel="stylesheet" href="styles.css" />
   </head>

   <body>
      <div id="main-wrap">
         <div id="fixed-container">
            <div id="container-a">
               <div id="container-b">
               </div>

               <div id="container-c">
               </div>
            </div>
         </div>

         <div id="showcase">

         </div>
      </div>

      <div id='btn-toggle'>
      </div>

      <!-- Scripts .js.-->
        <script src="jQuery-v211.js"> </script>
        <script src="mi-script.js"> </script>
   </body>
</html>


Código CSS :

*
{
   border:0;
   box-sizing: border-box; /* El padding y border del elemento no incrementan su ancho */
      -moz-box-sizing: border-box; /* moz = prefijo para mozilla firefox */
        -ms-sizing: border-box; /* ms = prefijo para Internet Explorer */
        -o-box-sizing: border-box; /* o = prefijo para mozilla Opera */
        -webkit-box-sizing: border-box; /* webkit = prefijo Chrome y Safari */
   margin: 0;
   outline: none;
   padding: 0;
   text-indent: 0;
}


#btn-toggle 
{
   position: fixed;
   bottom: 30px; /* Distancia desde abajo */
   right: 30px; /* Distancia desde la derecha */
   width: 60px; /* Ancho del botón */
   height: 60px; /* Alto del botón */
   display: block;
   background: url(flecha-arriba.png) no-repeat center center;
}


#container-a
{
   width: 80%; /* también puede ser el 100% total */
   background: green;
   height: 300px;
   margin: 0 auto;   
}

#container-b
{
   width: 50%;
   background: brown;
   height: 200px;
   margin: 0 auto;   
   float: left;
   margin-top: 45px;
}

#container-c
{
   width: 50%;
   background: yellow;
   height: 200px;
   margin: 0 auto;   
   float: left;
   margin-top: 45px;
}


#main-wrap
{
   background: blue;
   width: 100%;
}

#showcase
{
   width: 80%;
   background: pink;
   height: 5000px;
   margin: 0 auto; 
}



Código Javascript :

// boton para hacer "toggle" con el '#fixed-container'
$(document).ready(function(){
   $('#btn-toggle').on('click',function(){
      $('#fixed-container').slideToggle('slow');

      
   if ($('#fixed-container').show()) 
            {
            $('#btn-toggle').css('background-image', 'url(flecha-abajo.png)');
            } 
            else 
            {
            $('#btn-toggle').css('background-image', 'url(flecha-arriba.png)'); // OJO ESTE ES LO QUE NO ME HACE, VOLVER A MOSTRAR LA FLECHA HACIA ARRIBA
            }
   });
// hacer aparecer el boton al hacr scroll hacia abajo'
   $("#btn-toggle").hide();
      $(function () {
         $(window).scroll(function () {
            if ($(this).scrollTop() > 2000) 
            {
            $('#btn-toggle').fadeIn();
            } 
            else 
            {
            $('#btn-toggle').fadeOut();
            }
      });
   });
// hacer aparecer (si esta oculto) el div '#fixed-container' al hacer scroll hacia arriba'
   $(window).scroll(function () {
      if ($(this).scrollTop() < 2000) 
      {
      $('#fixed-container').slideDown();
      $('#btn-toggle').css('background-image', 'url(flecha-arriba.png)');
      } 
   });
}); 

Por Lord_Edoval

3 de clabLevel



Genero:Masculino  

Padawan de frontend

firefox
Citar            
MensajeEscrito el 15 Oct 2014 04:45 pm
Hola de nuevo, les dejo un link para ver el demo de mi ejercicio ... gracias...

Por Lord_Edoval

3 de clabLevel



Genero:Masculino  

Padawan de frontend

firefox
Citar            
MensajeEscrito el 16 Oct 2014 01:27 pm
Solucionado! :D en vez de utilizar CSS para las imágenes, lo mejor es utilizar clases de estilos, así es mas sencillo...

Aquí adjunto el código que modifica la flecha de subida por el de bajada y así sucesivamente.
En el html ponerle la clase "up" al div del boton:

Código HTML :

<div id='btn-toggle' class="up"> 
</div>


En el css agregar las clase #btn-toggle.up y #btn-toggle.down

Código CSS :

// OJO ESTE ES EL CSS DEL DIV CON POSITION FIXED, QUE EN EL CODIGO ANTERIOR NO LO COPIE
#fixed-container
{
   background:red;
   display:block;
   height: 300px;
   position: fixed;
   width: 100%;
   top:0; /* para pegarlo al tope de la pagina, y no al div que lo preceda */
}
//***************************************************************************************************************************
//Ahora si lo referente a el boton y las clases:
#btn-toggle 
{ 
   position: fixed; 
   bottom: 30px; /* Distancia desde abajo */ 
   right: 30px; /* Distancia desde la derecha */ 
   width: 48px; /* Ancho del botón */ 
   height: 48px; /* Alto del botón */ 
   display: block; 
}

#btn-toggle.down 
{ 
   background-image:url(flecha-abajo.png); 
} 

#btn-toggle.up 
{ 
   background-image:url(flecha-arriba.png); 
} 

y en el jquery hacer los cambios por medio de las clases:

Código Javascript :

$(document).ready(function(){ 
$('#btn-toggle').on('click',function(){ 
$('#fixed-container').slideToggle('slow'); 
if ($('#fixed-container').show()) { 
if($('#btn-toggle').hasClass("up")) { 
$('#btn-toggle').removeClass("up"); 
$('#btn-toggle').addClass("down"); } 
else 
{ 
$('#btn-toggle').removeClass("down"); 
$('#btn-toggle').addClass("up"); 
} 
} 
});

 // hacer aparecer el boton al hacr scroll hacia abajo' 
$("#btn-toggle").hide(); 
$(function () { $(window).scroll(function () { 
if ($(this).scrollTop() > 2000) { 
$('#btn-toggle').fadeIn(); } 
else 
{ 
$('#btn-toggle').fadeOut(); 
} 
}); 
}); 
// hacer aparecer (si esta oculto) el div '#fixed-container' al hacer scroll hacia arriba
$(window).scroll(function () { 
if ($(this).scrollTop() < 2000) { 
$('#fixed-container').slideDown(); 
$('#btn-toggle').addClass("up"); 
} 
}); 
}); 


...y así si funciona perfecto! (Dejo la solución por si de pronto alguien la pudiere llega a necesitar) :wink:

Por Lord_Edoval

3 de clabLevel



Genero:Masculino  

Padawan de frontend

firefox

 

Cristalab BabyBlue v4 + V4 © 2011 Cristalab
Powered by ClabEngines v4, HTML5, love and ponies.