11 técnicas clásicas CSS hechas más simples con CSS3

jueves, enero 21, 2010
COMPARTE EL POST

css3

El uso de CSS se está empezando a remplazar por CSS3 que básicamente simplificará nuestro trabajo para realizar algunos efectos como bordes, animaciones y muchas otras cosas más, en el siguiente tutorial les voy a enseñar 11 técnicas CSS3 que puedes usar en vez de usar las tradicionales que por compatibilidad o por el uso de frameworks no es tan viable de usar.

#1 Bordes

Los bordes son un problema para muchos ya que por ejemplo, Firefox y Safari soportan la propiedad pero IE no, aqui vamos a ver el ejemplo con CSS2 con javascript vs CSS3 y nada más.

Forma clásica

  1. <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
  2. <script type="text/javascript" src="js/jquery.corners.js"></script>
  3. <script type="text/javascript">
  4. $(function(){ 
  5.     $('.box').corners('10px'); 
  6. }); 
  7. </script>
  8. <div class="box">
  9. <!--CONTENT-->
  10. </div>

Forma CSS3

  1. <style type="text/css">
  2. .box { 
  3. border-radius: 10px; 
  4. -moz-border-radius: 10px; 
  5. -webkit-border-radius: 10px; 
  6. </style>
  7. <div class="box">
  8. <!--CONTENT-->
  9. </div>

Aquí puedes ver un ejemplo en acción viendo que en la forma clásica no sólo se necesita de más códigos, sino de varios scripts a comparación de las hojas de estilo de CSS3

#2 Sombra exterior

Otro problema que en la actualidad se presenta es la forma de hacer sombras, como dije, el primero usando jQuery, el segundo CSS3

Forma clásica

  1. <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
  2. <script type="text/javascript" src="js/jquery.dropShadow.js"></script>
  3. <script type="text/javascript">
  4. $(function(){ 
  5.     $('.box').dropShadow({ 
  6.         left: 5, 
  7.         top: 5, 
  8.         opacity: 1.0, 
  9.         color: 'black' 
  10.     }); 
  11. }); 
  12. </script>
  13. <div class="box">
  14. <!--CONTENT-->
  15. </div>

Forma CSS3

  1. <style type="text/css">
  2. .box { 
  3. box-shadow: 5px 5px 2px black; 
  4. -moz-box-shadow: 5px 5px 2px black; 
  5. -webkit-box-shadow: 5px 5px 2px black; 
  6. </style>
  7. <div class="box">
  8. <!--CONTENT-->
  9. </div>

Aquí puedes ver el ejemplo en acción viendo que sin necesidad de saber mucho podemos ver que CSS3 ofrece más limpieza y simplificación que jQuery

#3 Sombra de texto

Forma clásica

  1. <style type="text/css">
  2. .font { 
  3. font-size: 20px; 
  4. color: #2178d9; 
  5. .fonts { 
  6. position: relative; 
  7. .fonts .font { 
  8. position: absolute; 
  9. z-index: 200; 
  10. .fonts .second { 
  11. top: 1px; 
  12. color: #000; 
  13. z-index: 100; 
  14. </style>
  15. <div class="fonts">
  16. <span class="font">The quick brown fox jumps over the lazy dog.</span>
  17. <span class="font second">The quick brown fox jumps over the lazy dog.</span>
  18. </div>

Forma CSS3:

  1. <style type="text/css">
  2. .font { 
  3. font-size: 20px; 
  4. color: #2178d9; 
  5. .font { 
  6. text-shadow: 0 1px 0 #000; 
  7. </style>
  8. <span class="font">The quick brown fox jumps over the lazy dog.</span>

Aquí puedes ver el ejemplo en acción

#4 Texto fancy

Forma clásica

  1. <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
  2. <script type="text/javascript" src="js/cufon.js"></script>
  3. <script type="text/javascript" src="js/loyal.js"></script>
  4. <script type="text/javascript">
  5. $(function(){ 
  6.     Cufon.replace('.classic .font'); 
  7. }); 
  8. </script>
  9. <style type="text/css">
  10. .font { 
  11. font-size: 20px; 
  12. </style>
  13. <span class="font">The quick brown fox jumps over the lazy dog.</span>

Forma CSS3

  1. <style type="text/css">
  2. @font-face { 
  3. font-family: 'Loyal'; 
  4. src: url('loyal.ttf'); 
  5. .font { 
  6. font-family: Loyal; 
  7. font-size: 20px; 
  8. </style>
  9. <span class="font">The quick brown fox jumps over the lazy dog.</span>

Aquí puedes ver el ejemplo en acción

#5 Opacidad

El primer ejemplo muestra en distintos modos de navegadores el efecto de opacity, en CSS3 el estándar es simplemente opacity para cualquier navegador.

Forma clásica:

  1. <style type="text/css">
  2. .box { 
  3. opacity: .6; // all modern browsers (this is CSS3) 
  4. -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)"; // IE 8 
  5. filter: alpha(opacity=60); // IE 5-7 
  6. </style>
  7. <div class="box">
  8. <!--CONTENT-->
  9. </div>

Forma CSS3:

  1. <style type="text/css">
  2. .box { 
  3. opacity: .6; 
  4. </style>
  5. <div class="box">
  6. <!--CONTENT-->
  7. </div>

Aquí puedes ver el ejemplo en acción

#6 RGBA

Un método que hace que la imagen tenga un tono distinto o se cambie de color algún objeto, el primero usa PHP y CSS, el segundo la propiedad RGBA

Forma clásica

  1. <?php
  2. $image = imagecreatetruecolor(1, 1); 
  3. $r = (int)$_GET['r']; 
  4. $g = (int)$_GET['g']; 
  5. $b = (int)$_GET['b']; 
  6. $a = (float)$_GET['a']; 
  7. $white = imagecolorallocate($image, 255, 255, 255); 
  8. $color = imagecolorallocatealpha($image, $r, $g, $b, 127*(1-$a)); 
  9. imagefill($image, 0, 0, $white); 
  10. imagefilledrectangle($image, 0, 0, 1, 1, $color); 
  11. header('Content-type: image/png'); 
  12. imagepng($image); 
  13. ?>
  1. <style type="text/css">
  2. .box { 
  3. background: url(rgba.php?r=239&g=182&b=29&a=.25); 
  4. </style>
  5. <div class="box">
  6. <!--CONTENT-->
  7. </div>

Forma CSS3:

  1. <style type="text/css">
  2. .box { 
  3. background: rgba(239, 182, 29, .25); 
  4. </style>
  5. <div class="box">
  6. <!--CONTENT-->
  7. </div>

Aquí puedes ver el ejemplo en acción

#7 Tamaño de fondos

El primer ejemplo muestra la forma de darle tamaño a un fondo de imagen usando varios estilos y propiedades, el segundo usa la propiedad size para lograr el efecto.

Forma clásica:

  1. <style type="text/css">
  2. .box { 
  3. position: relative; 
  4. overflow: hidden; 
  5.     .box img { 
  6.     position: absolute; 
  7.     top: 0; 
  8.     left: 0; 
  9.     width: 50%; 
  10.     height: 50%; 
  11.     z-index: 100; 
  12.     } 
  13.     .box .content { 
  14.     position: absolute; 
  15.     z-index: 200; 
  16.     } 
  17. </style>
  18. <div class="box">
  19. <div class="content">
  20. <!--CONTENT-->
  21. </div>
  22. <img src="http://nettuts.s3.cdn.plus.org/423_screenr/200x200.jpg" alt="" />
  23. </div>

Forma CSS3:

  1. <style type="text/css">
  2. .box { 
  3. background: #ccc url(http://nettuts.s3.cdn.plus.org/423_screenr/200x200.jpg) no-repeat; 
  4. -webkit-background-size: 50%; /* Safari */ 
  5. -o-background-size: 50%; /* Opera */ 
  6. -khtml-background-size: 50%; /* Konqueror */ 
  7. </style>
  8. <div class="box">
  9. <!--CONTENT-->
  10. </div>

Aquí puedes ver el ejemplo en acción

#8 Múltiples fondos

El objetivo en el primer ejemplo es crear dos capas con estilos distintos que contienen fondos de imágenes, el segundo une las dos imágenes en un estilo y una capa

Forma clásica:

  1. <style type="text/css">
  2. .box { 
  3. width: 200px; 
  4. height: 150px; 
  5. background: url(images/bg.png) repeat-x; 
  6.     .box2 { 
  7.     width: 100%; 
  8.     height: 100%; 
  9.     background: url(images/text.png) center center no-repeat; 
  10.     } 
  11. </style>
  12. <div class="box">
  13. <div class="box2">
  14. <!--CONTENT-->
  15. </div>
  16. </div>

Forma CSS3:

  1. <style type="text/css">
  2. .box { 
  3. width: 200px; 
  4. height: 150px; 
  5. background: url(images/text.png) center center no-repeat, url(images/bg.png) repeat-x; 
  6. </style>
  7. <div class="box">
  8. <!--CONTENT-->
  9. </div>

Aquí puedes ver el ejemplo en acción

#9 Columnas

En el primer ejemplos se usa jQuery para poder crear dos columnas separando el texto para formarlo, en el segundo se define una propiedad column para poder especificar el número de columnas.

Forma clásica:

  1. <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
  2. <script type="text/javascript" src="js/jquery.columnize.js"></script>
  3. <script type="text/javascript">
  4. $(function(){ 
  5.     $('.columns').columnize({ 
  6.         columns: 2 
  7.     }); 
  8. }); 
  9. </script>
  10. <style type="text/css">
  11. .column { 
  12. padding-right: 10px; 
  13. .column.last { 
  14. padding: 0; 
  15. </style>
  16. <div class="columns">
  17. <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla elementum accumsan mi. Maecenas id dui a magna tempor pretium. Quisque id enim. Proin id tortor. Curabitur sit amet enim vitae quam pharetra imperdiet. Nulla diam ante, pellentesque eu, vestibulum non, adipiscing nec, eros. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Duis a nunc. Donec non dui a velit pulvinar gravida. Nunc rutrum libero vel tortor. Duis sed mi eu metus tincidunt ullamcorper. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. In purus lorem, aliquam ac, congue ac, vestibulum quis, felis. Aliquam non sapien.</p>
  18. <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla elementum accumsan mi. Maecenas id dui a magna tempor pretium. Quisque id enim. Proin id tortor. Curabitur sit amet enim vitae quam pharetra imperdiet. Nulla diam ante, pellentesque eu, vestibulum non, adipiscing nec, eros. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Duis a nunc. Donec non dui a velit pulvinar gravida. Nunc rutrum libero vel tortor. Duis sed mi eu metus tincidunt ullamcorper. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. In purus lorem, aliquam ac, congue ac, vestibulum quis, felis. Aliquam non sapien.</p>
  19. </div>

Forma CSS3:

  1. <style type="text/css">
  2. .columns { 
  3. -moz-column-count: 2; 
  4. -webkit-column-count: 2; 
  5. </style>
  6. <div class="columns">
  7. <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla elementum accumsan mi. Maecenas id dui a magna tempor pretium. Quisque id enim. Proin id tortor. Curabitur sit amet enim vitae quam pharetra imperdiet. Nulla diam ante, pellentesque eu, vestibulum non, adipiscing nec, eros. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Duis a nunc. Donec non dui a velit pulvinar gravida. Nunc rutrum libero vel tortor. Duis sed mi eu metus tincidunt ullamcorper. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. In purus lorem, aliquam ac, congue ac, vestibulum quis, felis. Aliquam non sapien.</p>
  8. <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla elementum accumsan mi. Maecenas id dui a magna tempor pretium. Quisque id enim. Proin id tortor. Curabitur sit amet enim vitae quam pharetra imperdiet. Nulla diam ante, pellentesque eu, vestibulum non, adipiscing nec, eros. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Duis a nunc. Donec non dui a velit pulvinar gravida. Nunc rutrum libero vel tortor. Duis sed mi eu metus tincidunt ullamcorper. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. In purus lorem, aliquam ac, congue ac, vestibulum quis, felis. Aliquam non sapien.</p>
  9. </div>

Aquí puedes ver el ejemplo en acción

#10 Borde de imágenes

Crear un borde con imágenes haciendolo con librerías y funciones en el primer ejemplo, en el segundo se define el estilo para cada navegador con la url de la imagen simulando el mismo resultado

Forma clásica:

  1. <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
  2. <script type="text/javascript" src="js/jquery.borderImage.js"></script>
  3. <script type="text/javascript">
  4. $(function(){ 
  5.     $('.classic .box').borderImage('url(images/border.png) 27 27 27 27 round round'); 
  6. }); 
  7. </script>
  8. <style type="text/css">
  9. .box { 
  10. border-width: 20px; 
  11. </style>
  12. <div class="box">
  13. <!--CONTENT-->
  14. </div>

Forma CSS3:

  1. <style type="text/css">
  2. .box { 
  3. border-width: 20px; 
  4. -webkit-border-image: url(images/border.png) 27 round; 
  5. -moz-border-image: url(images/border.png) 27 round; 
  6. border-image: url(images/border.png) 27 round; 
  7. </style>
  8. <div class="box">
  9. <!--CONTENT-->
  10. </div>

Aquí puedes ver el ejemplo en acción

#11 Animaciones

Se pretende usar jQuery en el primer ejemplo donde puedes manejar animaciones, en el segundo ejemplo se pretende hacer lo mismo con CSS usando estilos que hacen el barrido sin necesidad de script

Forma clásica:

  1. <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
  2. <script type="text/javascript">
  3. $(function(){ 
  4.     $('.box').hover(function(){ 
  5.         $(this).stop().animate({ 
  6.             top: '20px' 
  7.         }, 300); 
  8.     }, function(){ 
  9.         $(this).stop().animate({ 
  10.             top: '0' 
  11.         }, 300); 
  12.     }); 
  13. }); 
  14. </script>
  15. <style type="text/css">
  16. .box { 
  17. position: relative; 
  18. </style>
  19. <div class="box">
  20. <!--CONTENT-->
  21. </div>

Forma CSS3:

  1. <style type="text/css">
  2. .box { 
  3. position: relative; 
  4. -webkit-transition: top 300ms linear; 
  5. .box:hover { 
  6. top: 20px; 
  7. </style>
  8. <div class="box">
  9. <!--CONTENT-->
  10. </div>

Aquí puedes ver el ejemplo en acción

Vía Tutplus

¡Síguenos en Twitter!


Deja tu comentario