24/03/2010, 14:22
|
| | Fecha de Ingreso: marzo-2007
Mensajes: 17
Antigüedad: 17 años, 8 meses Puntos: 0 | |
Respuesta: ¿Se puede hacer esto con jQuery? Cita:
Iniciado por masterojitos hahaha...... ahora si nos entendemos..... y por que no mostraste el link desde un inicio.
el funcionamiento de eso, en si es tener un div con una imagen de fondo.
cuando haces el over, aparece con fade otro div encima del anterior con la imagen respectiva y obviamente en el out, se desvanece y otra vez se visualiza el anterior fondo.
aqui te paso una libreria creado en base a jquery para crear eso amigo. fade.js
Código Javascript :
Ver original// wrap as a jQuery plugin and pass jQuery in to our anoymous function (function ($) { $.fn.cross = function (options) { return this.each(function (i) { // cache the copy of jQuery(this) - the start image var $$ = $(this); // get the target from the backgroundImage + regexp var target = $$.css('backgroundImage').replace(/^url|[\(\)'"]/g, ''); // nice long chain: wrap img element in span $$.wrap('<span style="position: relative; "></span>') // change selector to parent - i.e. newly created span .parent() // prepend a new image inside the span .prepend('<img border="0">') // change the selector to the newly created image .find(':first-child') // set the image to the target .attr('src', target); // the CSS styling of the start image needs to be handled // differently for different browsers if ($.browser.msie || $.browser.mozilla) { $$.css({ 'border' : '0px', 'position' : 'absolute', 'left' : 0, 'background' : '', 'top' : this.offsetTop }); } else if ($.browser.opera && $.browser.version < 9.5) { // Browser sniffing is bad - however opera < 9.5 has a render bug // so this is required to get around it we can't apply the 'top' : 0 // separately because Mozilla strips the style set originally somehow... $$.css({ 'border' : '0px', 'position' : 'absolute', 'left' : 0, 'background' : '', 'top' : "0" }); } else { // Safari $$.css({ 'border' : '0px', 'position' : 'absolute', 'left' : 0, 'background' : '' }); } // similar effect as single image technique, except using .animate // which will handle the fading up from the right opacity for us $$.hover(function () { $$.stop().animate({ opacity: 0 }, 200); }, function () { $$.stop().animate({ opacity: 1 }, 200); }); }); }; })(jQuery); // note that this uses the .bind('load') on the window object, rather than $(document).ready() // because .ready() fires before the images have loaded, but we need to fire *after* because // our code relies on the dimensions of the images already in place. $(window).bind('load', function () { $('img.fade').cross(); }); //-->
para utilizarla.... debes previamente referenciar el jquery, luego a esta libreria (dale click a ver original y copia todo en un archivo js)..... <script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="fade.js"></script>
y para utilzar el efecto es asi de sencillo. <img src="imagen1.jpg" class="fade" style="background: url(imagen2.jpg)" />
y listo.
Suerte. Hola masterojitos, como puedo hacer que un boton con las mismas caracteristicas que describiste, me abra una galeria emergente tipo shadowbox, ligthbox.
Porfa si me puedes ayudar soy novato en este tema.
saludos |