Форум программистов, компьютерный форум, киберфорум
HTML, CSS
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
2 / 2 / 0
Регистрация: 31.05.2017
Сообщений: 18

Почему иногда не срабатывает transition-duration ?

01.11.2022, 18:58. Показов 603. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть два label связанные с radio r1 и r2, которые, в свою очередь, определены в контейнере вместе с блоком класса cube:
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<div class="container">
        <input type="radio" name="rotate" id="r1" />
        <input type="radio" name="rotate" id="r2" />
        <div class="cube">
            <div class="side front">     front    </div>
            <div class="side back">     back    </div>
            <div class="side left">       left      </div>
            <div class="side right">     right    </div>
            <div class="side top">       top      </div>
            <div class="side bottom"> bottom </div>
        </div>
        <div class="labels">
            <label for="r1" class="label"></label>
            <label for="r2" class="label"></label>
        </div>
</div>
При нажатии на label предполагается 3d трансформация блока класса cube (transform: rotate3d(1,1,1, 18000deg) при нажатии на label for r1; transform: rotate3d(1,1,1, 0deg) при нажатии на label for r2). Так я это реализовал на css:
CSS
1
2
3
4
5
6
7
#r1:checked ~ .cube {
    transform: rotate3d(1,1,1,0deg);
    transition-duration: 3s;
}r2:checked ~ .cube {
    transform: rotate3d(1,1,1, 18000deg);
    transition-duration: 100s;
}
Но очень часто*, при нажатии на l1 - анимация перехода длиться как по умолчанию: 200ms, а не прописанные 3s (причём не важно, нажали мы на неё до того как закончилась анимация 3d трансформации от нажатия на l2 или когда она уже закончилась).

Посмотреть можете здесь: http://students.ami.nstu.ru/~pmi-b0602/kub.html

html и css файлы, если нужно:
CSS
CSS
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
* {
    /*margin: 0;
    padding: 0;*/
    box-sizing:border-box;
}
:root {
    --index: calc(1vw + 1vh);
}
body{
    background-color:indigo;
}
.container {
    position: relative;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    /*margin: calc(var(--index) * 4) auto;*/
    width: calc(var(--index) * 6);
    height: calc(var(--index) * 6);
    /*background-color: black;*/
    perspective: calc(var(--index) * 10);
}
 
.cube {
    width: inherit;
    height: inherit;
    color: white;
/*    border: 5px solid #f00;*/
    transform-style: preserve-3d;
}
 
.side {
    position: absolute;
    width: inherit;
    height: inherit;
    border: calc(var(--index) / 5) solid #fff;
    font: normal calc(var(--index)*1.4) Arial;
    text-align: center; /*DELETE*/
    line-height: calc(var(--index) * 6 );
 
 
    color: white;
}
.front {
    transform: translateZ(calc(var(--index) * 3));
}
.back {
    transform: rotateY(180deg) translateZ(calc(var(--index) * 3));
}
.left {
    transform: rotateY(90deg) translateZ(calc(var(--index) * 3));
}
.right {
    transform: rotateY(-90deg) translateZ(calc(var(--index) * 3));
}
.top {
    transform: rotateX(90deg) translateZ(calc(var(--index) * 3));
}
.bottom {
    transform: rotateX(-90deg) translateZ(calc(var(--index) * 3));
}
 
.cube {
/*    transform: rotate3d(1,1,1,45deg);*/
    /*transition-duration: .6s;*/
}
 
 
input[name="rotate"] {
    position: absolute;
    visibility: hidden;
} /*Скрыли radio*/
.labels {
    position: relative;
    margin-top: calc(var(--index) * 3);
    width: calc(var(--index) * 6);
    height: calc(var(--index) * 2.4);
    display: flex;
}
.label {
    display: block; /*Обязательно для отображения label-ов!!!!!!!!!!!!!!*/
    position: relative;
    margin: calc(var(--index) / 6.67); /*коэфициент подобран так, чтобы label-ы при наведении соприкасались*/
    width: calc(var(--index) * 3);
    height: calc(var(--index) * 1.2);
    border-radius: calc(var(--index));
    background-color: #d0d0d0;
    opacity: 0.5;
}
.label:hover {
    transform: scale(1.2);
    transition-duration: .4s;
}
.radio:enabled {
    opacity: 0.8;
}
 
/*.r1 {
    position: fixed;*/ /*???????????????????????*/
/*}*/
 
#r1:checked ~ .cube {
    transform: rotate3d(1,1,1,0deg);
    transition-duration: 3s;
}
#r2:checked ~ .cube {
    transform: rotate3d(1,1,1, 18000deg);
    transition-duration: 100s;
}
 
 
 
 
.text {
    position: absolute;
    left: 50%;
    top: 4vh;
    transform: translateX(-50%);
    color: whitesmoke;
    font: normal calc(var(--index)*2) Arial;
    opacity: 0.9;
}
.footer {
    position: absolute;
    width:100%;
    bottom: 1vh;
    color: whitesmoke;
    text-align: center;
    opacity: 0.5;
}

HTML
HTML5
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
28
29
30
31
32
33
34
35
<html>
 
<head>
    <link rel="stylesheet" href="css\style.css" />
    <title>Ñube css only</title>
</head>
 
<body>
    <div class="text">
        3D cube <br> ONLY CSS
    </div>
    <div class="container">
        <input type="radio" name="rotate" id="r1" />
        <input type="radio" name="rotate" id="r2" />
        <div class="cube">
            <div class="side front"> front </div>
            <div class="side back">  back  </div>
            <div class="side left">  left  </div>
            <div class="side right"> right </div>
            <div class="side top">   top   </div>
            <div class="side bottom">bottom</div>
        </div>
        <div class="labels">
            <label for="r1" class="label"></label>
            <label for="r2" class="label"></label>
        </div>
    </div>
    <footer class="footer">&copy;JovenkoStyle 2022</footer>
    <!--<div class="container">
        <input type="checkbox" name="check_b" id="ch" />
        <label for="ch" class="check"></label>
    </div>-->
</body>
 
</html>


Добавлено через 3 минуты
* transition-duration работает нормально, если не давать закончиться трансформации от первой кнопки. Если один раз трансформация от нажатия l1 была закончена: всегда далее duration будет 200ms (но только для трансформации от первой кнопки, duration для второй останется 100s). (см. прикреплённую реализацию).
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.11.2022, 18:58
Ответы с готовыми решениями:

Некорректно работает transition-duration
Добрый день! Я уже замучился, не пойму в чем проблема. Делаю так, чтобы при наведении на главный пункт меню, сверху плавно выезжали...

Почему иногда не срабатывает функция __autoload
Здравствуйте. Классы подключаются с помощью функции __autoload(). Но в некоторых места, у меня выскакивает фатальная ошибка о том , что...

Почему иногда не срабатывает код RewriteRule в .htaccess?
Сайт работает на своей собственной разработанной CMS. Почему в редких случаях по клике по ссылке не срабатывает код RewriteRule в .htaccess...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.11.2022, 18:58
Помогаю со студенческими работами здесь

Почему иногда не срабатывает функция итогов в табличной форме?
Добрый день всем. Неоднократно натыкался на подобное, в конце концов решил спросить у знающих, в чем может быть причина. Допустим,...

Что такое -webkit-transition, -moz-transition, -o-transition?
Изучаю анимацию в css с помощью transition. В каждом примере вижу похожую запись. -webkit-transition: top 1s ease-out 0.5s; ...

Почему иногда отслеживается нажатие на три клавиши сразу, а иногда нет
Доброй ночи, кто может объяснить почему иногда отслеживает нажатие на три кнопки сразу, а иногда нет. И как выйти с ситуации *( P.S. Пишу...

Почему иногда функции передается значение int, а иногда - нет?
1 случай: void Function_1(int* &amp; rVarOne, int* &amp;rVarTwo) { /* Какие-то операции с указателями: rVarOne++; *rVarOne =...

Почему программа иногда возвращает не нулевой результат, а иногда нуль?
С чем подобное может быть связана?


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
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
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru