Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
8 / 8 / 3
Регистрация: 01.03.2013
Сообщений: 85

Анимация глючит в Firefox при масштабировании блока

09.07.2014, 01:07. Показов 2227. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет

Столкнулся с такой проблемой. Мне надо изменять размеры блока и его содержимого. Пытался найти красивое и элегантное решение и нашел. Свойство zoom в стилях объекта. В хроме и сафари все работает на ура, но вот в Firefox работает супер коряво. В Firefox надо использовать -moz-transform + немного разобраться с позиционированием объекта. Ладно, с этим я разобрался, но осталась такая проблема. Когда анимация стартует, инициализируется неверное значение, а именно 0. Как можно подставить не нуль, а правильное значение? Вот, примерно, как я это пытаюсь сделать:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
$(elem).animate({
    zoom: lRatio,
}, {
    step: setZoom,
    complete: finishFunc,
    start: startAmin
});
 
// проверка и поправка zoom, если вдруг Firefox
var setZoom = function(val, obj) {
        if(this === carousel.children('li')[3] && obj.prop === "zoom") console.log(val, obj);
        if(obj.prop === "zoom") {
            $(this).css({
                "MozTransform": "scale(" + val + ")",
                "zoom": val
            });
        }        
    };
 
// пытаюсь инициализировать стартовое значение для zoom, но никакого эффекта
var startAmin = function(obj) {
        if (obj.props.hasOwnProperty('zoom')){
            console.log(obj.props.zoom, $(obj.elem).css("MozTransform"), parseFloat(($(obj.elem).css("MozTransform")?$(obj.elem).css("MozTransform"):$(obj.elem).css("zoom")).replace(/^matrix\(((\d|\.)+?),.*?$/, '$1')));
            obj.props.zoom = parseFloat(($(obj.elem).css("MozTransform")?$(obj.elem).css("MozTransform"):$(obj.elem).css("zoom")).replace(/^matrix\(((\d|\.)+?),.*?$/, '$1'));
            return obj;
        }
    };
Всем заранее огромное спасибо
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.07.2014, 01:07
Ответы с готовыми решениями:

анимация при смене блока
добрый день ребята. не знаю как это объяснить но надо сделать анимацию для смены одного дива на другой. попробую как нибудь...

Анимация блока при клике
Добрый день! Подскажите пожалуйста, как сделать что бы при клике на бок он плавно смещался вверх. Как добавить класс с...

Анимация для блока при наведении
Есть блок, по сути иконка в меню.Нужно, чтобы при наведении на иконку появлялся другой блок (есть анимация, при которой он двигается влево)...

1
128 / 126 / 60
Регистрация: 22.01.2014
Сообщений: 464
09.07.2014, 20:18
Проблема здесь в том, что свойство zoom(CSS) не поддерживается всеми браузерами. Поэтому при инициализации .animate оно будет инициализированно 0, теми браузерами, которые не поддерживают его. Но можно подменить его(начальное значение), в функции
JavaScript
1
2
3
4
5
6
7
8
startZoom=1;
var setZoom = function(val, obj) {
    obj.start=startZoom;
    $(obj.elem).css({
        "transform":" scale("+val+","+val+')' 
        }
    );
}
Но возможно, что первый кадр будет немного дергаться(в недрах jquery).
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.07.2014, 20:18
Помогаю со студенческими работами здесь

Анимация одного блока при нажатии на другой блок
Помогите, пожалуйста, решить следующую задачу. Скрипт - это иконка меню (три полоски), при нажатии на которую происходит анимация, и...

При масштабировании в Firefox почему-то меняются размеры экрана в css медиа запросе
Использую такой медиа-запрос для вывода картинки: <picture> <source srcset="/jpg/mos01s1.jpg" media="(min-device-width:...

Как зафиксировать размеры блока при масштабировании в браузере?
Скажите пожалуйста мне нужно чтобы в правом угле была стрелка(картинкой) но когда я колёсиком мыши уменьшаю и увеличиваю то мне нужно...

Div выходит за пределы родительского блока при масштабировании (+скрин)
Есть внешний div (outer-outer), первый внутренний (outer), второй внутренний (inner) и внутри него третий div (content). При...

Глючит FireFox
FireFox стал сильно тормозить (подвисание страниц, флэш видео прерывисто идет, html5 нормально) и в целом ноутбук как то тяжелее стал...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия SDL 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual. . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru