- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用的一个 div 就像完成的消息一样。它应该在进程完成时出现并在几秒钟后消失。为此,我编写了这个小代码片段:
function showProcessFinishedMsg(msg) {
var done_msg = document.getElementById("done_msg");
var done_msg_text = document.getElementById("done_msg_text");
done_msg_text.innerHTML = msg;
unfade(done_msg);
setTimeout(fade(done_msg),60000);
}
//fading in
function unfade(element) {
var op = 0.1; // initial opacity
element.style.display = 'block';
var timer = setInterval(function () {
if (op >= 1){
clearInterval(timer);
}
element.style.opacity = op;
element.style.filter = 'alpha(opacity=' + op * 100 + ")";
op += op * 0.1;
}, 10);
}
//fading out
function fade(element) {
var op = 1; // initial opacity
var timer = setInterval(function () {
if (op <= 0.1){
clearInterval(timer);
element.style.display = 'none';
}
element.style.opacity = op;
element.style.filter = 'alpha(opacity=' + op * 100 + ")";
op -= op * 0.1;
}, 50);
}
.done_msg {
height: 50px;
width: 80%;
left: 0;
right: 0;
margin-left: auto;
margin-right: auto;
position: absolute;
bottom: 20px;
background-color: #212121;
border-radius: 8px;
box-shadow: 1px 1px 5px #0d0d0d;
text-align: center;
display: flex;
justify-content: center;
align-items: center;
}
.done_msg_text {
padding-left: 30px;
color: #ffffff;
}
<div class="done_msg" id="done_msg" style="display: none;">
<img src="./done.png" width="33px" height="auto">
<p class="done_msg_text" id="done_msg_text">icbsiudbisbdvoaodvnoda</p>
</div>
<button onclick="showProcessFinishedMsg('Maybe it works, in a different universe.')">Testbutton</button>
但如您所见,我遇到了问题,即它运行不顺畅。而且闪烁的很诡异。希望有人能帮助我。
~菲利普
最佳答案
您的问题在于:
setTimeout(fade(done_msg), 60000);
在这里,您在执行此行时调用 fade
函数,而不是像您认为的那样每分钟调用一次。
setTimeout
的第一个参数应该是一个可以执行的函数,但是,您正在立即执行该函数,因此您将第一个参数设置为返回值fade
是 undefined
。
这会导致您的unfade
和fade
函数同时运行,从而导致闪烁。相反,将 fade(done_msg)
包装在它自己的函数中:
setTimeout(_ => fade(done_msg), 60000);
请参阅下面的工作示例:
function showProcessFinishedMsg(msg) {
var done_msg = document.getElementById("done_msg");
var done_msg_text = document.getElementById("done_msg_text");
done_msg_text.innerHTML = msg;
unfade(done_msg);
setTimeout(_ => fade(done_msg), 2000);
}
//fading in
function unfade(element) {
var op = 0.1; // initial opacity
element.style.filter = 'alpha(opacity=' + op * 100 + ")";
element.style.display = 'flex';
var timer = setInterval(function() {
if (op >= 1) {
clearInterval(timer);
}
element.style.opacity = op;
element.style.filter = 'alpha(opacity=' + op * 100 + ")";
op += op * 0.1;
}, 10);
}
//fading out
function fade(element) {
var op = 1; // initial opacity
var timer = setInterval(function() {
if (op <= 0.1) {
clearInterval(timer);
element.style.display = 'none';
}
element.style.opacity = op;
element.style.filter = 'alpha(opacity=' + op * 100 + ")";
op -= op * 0.1;
}, 50);
}
.done_msg {
height: 50px;
width: 80%;
left: 0;
right: 0;
margin-left: auto;
margin-right: auto;
position: absolute;
bottom: 20px;
background-color: #212121;
border-radius: 8px;
box-shadow: 1px 1px 5px #0d0d0d;
text-align: center;
display: flex;
justify-content: center;
align-items: center;
}
.done_msg_text {
padding-left: 30px;
color: #ffffff;
}
<div class="done_msg" id="done_msg" style="display: none;">
<img src="./done.png" width="33px" height="auto">
<p class="done_msg_text" id="done_msg_text">icbsiudbisbdvoaodvnoda</p>
</div>
<button onclick="showProcessFinishedMsg('Maybe it works, in a different universe.')">Testbutton</button>
关于javascript - 超时淡入淡出时div闪烁,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55077048/
我是 Jetpack Compose 的新手。我目前正在开发一个聊天应用程序。我要求用户从图库中选择图像或从相机中拍照。然后我将文件 Uri 保存到数据库中,然后收听所有消息的列表。更新此列表时,此图
强制性代码,但 jsFiddle 准确地演示了这个问题。我有一个在 3 秒内扩大和淡出的圆圈。声纳风格是我的意图。问题是动画完成后它会快速“闪烁”然后重新开始。 请在此处查看问题:http://jsf
您好,我有一个多种颜色的 Logo ,我想将其用于随机/不稳定的故意闪烁效果。我只能找到其他关于使用淡入/淡出功能进行闪烁技巧的文章。关于如何用 css3 和/或 jQuery 做这样的技巧有什么想法
我正在使用 Swing 创建组件并使用 GLCanvas (com.jogamp.opengl.awt.GLCanvas) 创建我的窗口。 接下来就是问题了 在初始状态下,一切正常,但是当我拖动窗口调
我将 PhoneGap 2.2.0 与 jQuery Mobile 1.2.0 结合用于我在 Android 平台(版本 2.3.3 及更高版本)上的应用程序。在我使用固定标题的页面上,根本没有转换。
在我们使用 JavaScript 向页面添加图像或文本后,我们的网页在 iPad 上闪烁。我们尝试了 -webkit-backface-visibility:hidden; 的各种组合; -webki
有人能告诉我为什么在这个使用 SwingWorker 的简单演示中,屏幕闪烁,好像按钮不断跳跃一样? (关于改进多线程部分的反馈也值得赞赏)。 import java.awt.EventQueue;
我正在运行时从 CSV 文件向字符串网格添加多行,但是 StringGrid 在更新时似乎会闪烁很多,我认为会有一个 beginupadate/Endupdate 命令来停止此操作。但是我找不到它。有
我的窗口中有一个文本元素,我希望它每隔几秒或几毫秒闪烁一次或出现并消失。 我的代码是: import QtQuick 2.6 import QtQuick.Window 2.2 Window {
我的窗口中有一个文本元素,我希望它每隔几秒或几毫秒闪烁一次或出现并消失。 我的代码是: import QtQuick 2.6 import QtQuick.Window 2.2 Window {
我在UIButtons中有3个UIView,它们具有相同的文本颜色和相同的背景颜色。轻按三个按钮即可触发相应的事件。但是只有其中之一会响应触摸而“闪烁”。其他两个会发生什么?它们有时(但很少)具有“闪
我在 iOS 8 下实现 UIRefreshControl 时遇到了一种闪烁。每次我第一次到达 tableView 的顶部时(即应用程序刚刚启动时),我都会看到下面的 gif 中显示的闪烁。这不会发生
我希望有人能帮助我。我遇到以下问题: http://jsfiddle.net/zhPAF/ 标记: About Us
当鼠标悬停在图像“A”上时,尝试让图像“B”覆盖在图像“A”上。理想情况下,我希望它淡入。 HTML: jQuery:
我有一个 TabControl,我可以在其中添加/删除多个 TabPage。 当我添加足够多的页面以至于必须显示导航按钮时,我遇到了闪烁问题。 当导航按钮(左右导航的 2 个箭头)未显示时,我根本没有
我尝试实现自定义双缓冲,但它会导致闪烁。 这是控件(继承自Control的自定义控件)构造函数中的代码: bufferContext = new BufferedGraphicsContext();
我有以下代码: var footer = $('.footer'), extra = 0; // footer.css({ opacity: '0', display: 'block' });
我遇到了与 JPanel 中闪烁相关的问题。不知道为什么, window 里的球时不时地闪烁。我尝试了几种方法,比如双缓冲、BufferStrategy、Canvas,但都不起作用。主要思想是使用线程
我试图在 OpenGL 中绘制一些文本,而程序绘制立方体或任何 Opengl native ,因此,当我尝试将文本放在屏幕上时,它闪烁得非常快,我不知道为什么,我试图改变 sleep 值什么都没有..
我已经使用 LibGDX UI Setup 启动了一个项目。 我在 implements ApplicationListener 中唯一拥有的是: public void create() {
我是一名优秀的程序员,十分优秀!