- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
当我尝试转换不透明度时,我遇到了转换链接的问题。否则它工作正常。没有不透明度,console.log 显示:
Transition no 1 started at: 1523817891340
Transition no 1 ended at: 1523817893361
Transition no 2 started at: 1523817893363
Transition no 2 ended at: 1523817895358
这是正确的(近似值)。
现在,如果我取消对不透明度过渡的注释,我会得到以下输出,这显然是错误的:
Transition no 1 started at: 1523818593850
Transition no 1 ended at: 1523818595856
Transition no 2 started at: 1523818595857
Transition no 2 ended at: 1523818595859
Transition no 2 ended at: 1523818597854
Transition no 2 ended at: 1523818597855
莫名其妙!请注意,第二次转换运行的时间非常短,这会触发其他问题!
...
<style>
.tryDiv {
width: 500px;
height: 500px;
background: red;
display : block;
}
</style>
...
<div class="tryDiv" ></div>
...
$(document).ready(function() {
countM=1;
/**** SET TRANSITION-END EVENT HANDLER *****/
$('.tryDiv').on('webkitTransitionEnd oTransitionEnd transitionEnd', function() {
console.log("Transition no " + (countM-1) + " ended at: " + new Date().getTime());
if (countM<=2) _startTransition();
});
function _startTransition() {
switch (countM) {
case 1: var transitionVal = 'opacity 2s, transform 2s, -webkit-transform 2s';
var css = {//opacity: 0.5,
transform: 'scale(.5)','-webkit-transform': 'scale(.5)'};
break;
case 2: var transitionVal = 'opacity 2s, transform 2s, -webkit-transform 2s';
var css = { //opacity: 1,
transform:'scale(1)','-webkit-transform': 'scale(1)'};
break;
}
$('.tryDiv').css('-ms-transition', transitionVal);
$('.tryDiv').css('-webkit-transition', transitionVal);
$('.tryDiv').css('-transition', transitionVal);
console.log("Transition no " + countM + " started at: " + new Date().getTime());
$('.tryDiv').css(css);
++countM;
};
/*** STARTS HERE BY EXECUTING FIRST TRANSITION ***/
_startTransition();
});
最佳答案
实际上,当您将 transition
应用于超过 1 条规则时,您将在大约同一时间获得 n 个“结束”日志;在您的情况下 - 动画开始后 2 秒(其中 n 是应用 transition
的规则数量)。发生这种情况是因为不同 css 规则的转换被认为是不同的转换事件。
你在第一个“开始”日志之后得到“第二个”“结束”日志的原因是因为它实际上对应于第一个动画,但是你的事件处理程序使用闭包中的变量值所以它输出 2
而不是 1
。
为了避免这种情况,您可以使用 setTimeout
和动画持续时间(2
或 2000
ms),为错误留出一点空间(例如,我将其设置为 2030
ms)。
这是 jsfiddle example (看看那里的控制台输出)。
关于javascript - 具有不透明度的 CSS3 过渡不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49845729/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!