- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
考虑这个 slider :
$(function() {
var $volumeBar = $('#Volume-Bar');
var $volumeContainer = $('#Volume-Container');
var $value = $('.value');
$volumeContainer.on('mousedown', function(event) {
var height = $volumeContainer.height();
var top = $volumeContainer.position().top;
var startingCoord = event.clientY - top;
var currentCoord;
var percent;
var difference;
seekingVol = true;
$volumeBar.css({
'background-color': '#dcb311',
});
$volumeContainer.on('mouseup mouseleave', function() {
if (seekingVol) {
seekingVol = false;
$volumeBar.css({
'background-color': '',
});
}
});
$volumeContainer.on('mousemove', function(event) {
if (seekingVol) {
currentCoord = event.clientY - top;
percent = ((height - currentCoord) / height) * 100;
$volumeBar.finish();
$volumeBar.css({
'height': percent + '%'
});
}
});
});
});
@import url(https://fonts.googleapis.com/css?family=Bitter:700);
#Volume-Container {
position: relative;
width: 75px;
height: 150px;
background-color: #0e2030;
display: -webkit-box;
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-webkit-flex-direction: column;
-ms-flex-direction: column;
flex-direction: column;
-webkit-box-align: center;
-webkit-align-items: center;
-ms-flex-align: center;
align-items: center;
-webkit-box-pack: center;
-webkit-justify-content: center;
-ms-flex-pack: center;
justify-content: center;
}
#Volume-Bar {
position: absolute;
bottom: 0px;
height: 30%;
width: 100%;
background-color: #6ab2f2;
transform-origin: bottom;
}
#Volume-Bar:hover {
background-color: #dcb311;
animation: Vert-Bounce 0.6s;
}
@keyframes Vert-Bounce {
0% {
transform: height(1);
}
25% {
transform: scaleY(1.3);
}
50% {
transform: scaleY(1);
}
75% {
transform: scaleY(1.15);
}
100% {
transform: scaleY(1);
}
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="Volume-Container">
<div id="Volume-Bar"></div>
</div>
注意到悬停时栏上的弹跳动画了吗?
当用户向上拉动条时,由于条的缩放和鼠标移动之间存在滞后,鼠标退出元素。当元素追上鼠标或用户向下拉回鼠标时,将在鼠标重新进入元素时触发另一个悬停事件。这会在用户拖动栏时多次触发弹跳动画。我想在 mousedown
上禁用此动画并在 mouseup
上重新激活它。
我该怎么做?
最佳答案
如果我理解得很好,弹跳动画发生在拖动时。
这就是问题所在。
我尝试了一些可能感兴趣的东西。我在事件监听器函数中使用了 mouseover
和 mouseout
事件...而不是 CSS hover
来处理弹跳效果。
$(function() {
var $volumeBar = $('#Volume-Bar');
var $volumeContainer = $('#Volume-Container');
var $value = $('.value');
$volumeBar.on('mouseover', function(event) { // Added this event function
$volumeBar.css({"background-color":"#dcb311","animation":"Vert-Bounce 0.6s"});
});
$volumeBar.on('mouseout', function(event) { // Added this event function
$volumeBar.css({"background-color":"#6ab2f2","animation":"initial"});
});
$volumeContainer.on('mousedown', function(event) {
var height = $volumeContainer.height();
var top = $volumeContainer.position().top;
var startingCoord = event.clientY - top;
var currentCoord;
var percent;
var difference;
seekingVol = true;
$volumeBar.css({
'background-color': '#dcb311',
});
$volumeContainer.on('mouseup mouseleave', function() {
if (seekingVol) {
seekingVol = false;
$volumeBar.css({
'background-color': '',
});
}
});
$volumeContainer.on('mousemove', function(event) {
if (seekingVol) {
currentCoord = event.clientY - top;
percent = ((height - currentCoord) / height) * 100;
$volumeBar.finish();
$volumeBar.css({
'height': percent + '%'
});
}
});
});
});
参见 fiddle :https://jsfiddle.net/Bes7weB/8fpqxhoe/
注意:
我给它添加了一个 6px 的填充:为了防止鼠标在拖动时 mouseout。
这可能是个问题...
关于javascript - 如何暂时禁用元素的 CSS 悬停触发动画?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37911668/
我正在使用 typedef 的第三方库s byte至 char . (这很糟糕,因为 char 可能是 signed 或 unsigned,具体取决于编译器的选择)。 不幸的是typedef已经溢出到
每当我做一个工作任务时,我都会在git中创建一个本地分支,然后我需要在实际工作之前修改一堆配置文件(主要包含数据库的连接字符串)以设置为我的本地环境。我不想在完成任务后将这些更改推送到存储库。 实际上
我有一个生成大量可能状态的方法,当使用 , 链接它时与(有条件的)fail或 tactic no_tac ,由此产生的组合方法需要很长时间才能终止并导致 Isabelle 界面滞后。但是,当使用两个
为了从转储中恢复数据库,我想暂时禁用数据库所有表中的所有约束,我清空了这些表的内容(postregsql 8.3)。 是否有一种安全的方法来修改 pg_constraint 表中的字段,从而轻松绕过约
在 my usecase我正在尝试同步两个 Elasticsearch 索引。由于版本控制,这实际上是 quite simple 。不过,我想在这样做的同时随时继续写作。 好的,我想按时间顺序执行的步
我需要在 Symfony (1.3.8) 支持的网站上执行升级/增强。该站点将至少离线几天。有谁知道如何使用 Symfony 框架设置“临时离线”页面? 最佳答案 以下是来自 A Gentle Int
我正在为 UIAlertView 创建一个包装器(我知道 UIAlertController 和一些已经存在的包装器,它也用于教育目的)。 假设它看起来像这样(非常简短的版本): @interface
一点背景—— 我运行一个使用 Java 运行的游戏服务器,以及一个使用 PHP (phpbb) 运行的论坛。我将游戏和论坛账号关联起来,这样在游戏中更改密码会自动更改论坛账号的密码。这两个系统使用不同
我在我的 System76 Oryx 笔记本电脑上使用 Ubuntu 16.04。触控板非常敏感,所以我曾经使用 Fn+F1 禁用它。这在 18.04 中不再起作用。我环顾四周,发现: synclie
当我对 Haskell 程序进行原型(prototype)设计时,我总是会收到数百条这样的警告(不是开玩笑): /Users/bob/SourceCode/course/is/expriment/Li
据我了解,如果我想在我的 EF6 应用程序中使用延迟加载,我应该将我的关系编码为这样,最后两项标记为虚拟: public class Test { public int TestId { ge
我正在一个有2d map 的项目中: QMap > slot_pic; 我设置了一个表来初始化值: slot_pic[0][0] = QPixmap("path..."); slot_pic[1][
我刚刚修改了 cytoscape.js 的示例(“动画 BFS”)并添加了一些节点: $(function(){ // on dom ready $('#cy').cytoscape({ style:
UIScroll View 让我在一页内容太多时声明一个可滚动区域。奇怪的是,有问题的 ScrollView 在 X 轴上的行为符合预期,不允许任何滚动。不幸的是,Y 轴——需要滚动的地方——不会将允
我是 Maven 新手,而且我也没有太多使用 Eclipse 的经验。 要从 Eclipse 中的构建中排除 java 文件,我右键单击这些文件并选择“构建路径”->“排除”。这对于 Eclipse
我从 GLM 库的 #pragma message 收到许多消息。有没有办法抑制这些,最好是暂时的(只针对那个库)? 最佳答案 我能想到的最佳解决方案是将 g++ 的输出通过管道传输通过过滤器,即 g
在现代浏览器上下文中的 JS 中(特别是 Chrome,但任何答案都很有趣)我如何临时覆盖 Object.prototype.toString 或任何其他 native 代码方法,以便新实现实际接收通
我是一名优秀的程序员,十分优秀!