Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

HTML+CSS+JavaScript

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: как сделать плавное изменение картинок ?
 
 автор: asker   (22.01.2012 в 22:27)   письмо автору
 
 

сейчас это реализовано так:

function image_control() {
var inspirations = ['img/quickview_340/sneakers.jpg', 'img/quickview_340/sneakers1.jpg', 'img/quickview_340/sneakers2.jpg'];
$('.inspiration_image').bind('click', function(event){
event.preventDefault();
var ins = inspirations[$(this).attr('id')]
//update main quickview image
$("#quickViewMainImage").fadeOut().attr("src", ins).fadeIn();
$("#quickViewMainImage").attr("src", ins);
$("#quickViewMainImage").fadeIn();
});
}


посмотреть работу можно здесь

но адрес картинки меняется еще до срабатывания fadeIn() из-за этого возникает ощущение что картинка дергается и грузится два раза, как этот процесс сделать плавнее и эстетичнее ? без дополнительный плагинов только на jQery.

  Ответить  
 
 автор: Valleri   (23.01.2012 в 06:11)   письмо автору
 
   для: asker   (22.01.2012 в 22:27)
 

Может от браузера зависит.
У меня такой эффект в Фоксе
Где посмотреть в действии?

  Ответить  
 
 автор: ONYX   (23.01.2012 в 10:23)   письмо автору
 
   для: asker   (22.01.2012 в 22:27)
 

Что вы делаете?

Скрываете картинку - меняете атрибут - показываете картинку
$("#quickViewMainImage").fadeOut().attr("src", ins).fadeIn();

тут же меняете атрибут на тот же самый, причем подгрузка предыдущей картинки не прекратилась
$("#quickViewMainImage").attr("src", ins);

И снова показываете картинку, вот вам и ощущение что картинка грузится два раза и дергается
$("#quickViewMainImage").fadeIn();

Достаточно этого куска кода:

function image_control() {
     var inspirations = ['img/quickview_340/sneakers.jpg', 'img/quickview_340/sneakers1.jpg', 'img/quickview_340/sneakers2.jpg'];
     $('.inspiration_image').bind('click', function(event){ 
         event.preventDefault(); 
         var ins = inspirations[$(this).attr('id')]
         //update main quickview image
         $("#quickViewMainImage").fadeOut().attr("src", ins).fadeIn();
 });
 }

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования