- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发一个元素,该元素使用基于 CSS 和 HTML 的百分比值条形表示。代码如下所示:
HTML:
<div class="chart">
<div class="bar" style="width:43%"></div>
</div>
CSS:
.chart {
background-color: #DADADA;
height: 2px;
position: relative;
}
.chart .bar {
background-color: #3D98C6;
height: 100%;
}
我想做的是在页面加载时从 0% 开始条形宽度,然后将其动画化为内联值。我希望该值是内联的,这样我们的后端开发人员就可以让 Ruby on Rails 只在 View 中输出一个百分比。我知道我可以通过转换来做到这一点,我目前正在这样做:
CSS:
.chart .bar {
-moz-transition: width 1.25s linear;
-webkit-transition: width 1.25s linear;
-ms-transition: width 1.25s linear;
-o-transition: width 1.25s linear;
transition: width 1.25s linear;
}
body.jquery.csstransitions:not(.loaded) .chart-container .chart .bar {
width: 0% !important;
}
JavaScript:
$(function() {
$('body').addClass('jquery');
// Way down in the code
$('body').addClass('loaded');
});
这表示虽然用户支持 JavaScript,但他们的浏览器支持 CSS 转换,并且“已加载”类尚未添加到正文中,所有栏的宽度均为 0%。一旦 .loaded 被添加到 jQuery 中,条形图就会全部转换为内联值。
我在使用此方法时遇到的问题是,用户启用 JavaScript 并添加“jquery”和“csstransitions”类的可能性很小,但在到达添加类 .loaded
的代码。这将导致条形图全部显示为 0% 宽度。我从事的这个元素有很多人参与其中,JavaScript 有可能在正确的地方中断,导致我们的用户看到损坏的图表。如果我可以改为使用 CSS 关键帧动画从 0% 宽度到内联宽度进行动画处理,那么我就可以将 JavaScript 排除在等式之外,并且知道代码可以为条形图设置动画,或者只是在没有动画的情况下加载它们。
有没有什么方法可以在不依赖 JavaScript 的情况下在页面加载时对宽度进行动画处理/过渡?
最佳答案
看来我的问题实际上很容易回答。我以前从未使用过 CSS 关键帧动画,也没有意识到它们基本上是根据时间有条件地应用样式,然后在它们之间进行动画处理。这意味着通过不为某个关键帧应用任何样式,下一个应用样式的行将只是动画化以代替空样式。这意味着我可以这样做:
HTML:
<div class="chart">
<div class="bar" style="width:43%;"></div>
</div>
CSS:
@-moz-keyframes animate-bar {
0% { width: 0%; }
}
@-webkit-keyframes animate-bar {
0% { width: 0%; }
}
@-ms-keyframes animate-bar {
0% { width: 0%; }
}
@-o-keyframes animate-bar {
0% { width: 0%; }
}
@-keyframes animate-bar {
0% { width: 0%; }
}
.chart {
background-color: #DADADA;
height: 2px;
position: relative;
}
.chart .bar {
background-color: #3D98C6;
height: 100%;
-moz-animation: animate-bar 1.25s 1 linear;
-webkit-animation: animate-bar 1.25s 1 linear;
-ms-animation: animate-bar 1.25s 1 linear;
-o-animation: animate-bar 1.25s 1 linear;
animation: animate-bar 1.25s 1 linear;
}
并且 0% 的开始动画将只对内联样式进行动画处理,因为没有结束样式意味着结束样式等同于覆盖该样式的任何内容。
编辑:
我创建了一个 JS Fiddle向 future 的访问者展示这一点。
关于jquery - CSS 关键帧 : animating/transitioning to an inline value on page load,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11234426/
我想使用 linux 终端在 .txt 文档中找到字符串 animal-0**。 ** 是从 60 到 69 的数字。我想我必须在命令中使用 grep 和正则表达式:grep -E 'animal-0
在他的C# 深入一书中,Jon Skeet 试图回答以下问题: Why can't I convert List to List? 为了解释它,他从一个代码片段开始,其中包括以下两行: Animal[
我对此有点困惑,所以希望能提供一些说明。 public void addAll(List animals) 对比 public void addAll(List animals) 最佳答案 区别在于
我遇到的情况是,我有许多CALayer以“基于回合”的方式进行动画处理。我为每个CALayer上的位置设置了动画,但是它们具有完全相同的持续时间。一旦所有这些CALayer动画完成,就会启动一个新的“
我为正在拔出的刀和空闲状态设置了动画,但是无论我做什么,它们都不会在游戏中设置动画。相反,它卡住在第一帧上。这是动画窗口运行时的样子: 动画: 在检查器中: 最佳答案 我遇到了类似的问题,它归结于动画
我的单个 HTML 文件中嵌入了 2 个页面。所以它所做的是最初它显示 PAGE1,然后如果我从右向左或从左向右滑动 PAGE2 应该显示。我的问题是如何根据我的滑动更改页面动画?比如当我从右向左滑动
我想做一个动画标题。 我创建了一个 FlatList 的动画组件, 用过 onScroll函数来更新动画值。 使用绝对位置放置一个 View (Animated.View) 作为动画 FlatList
我想制作一个打开的窗帘的动画。我有两张图像:一张用于窗帘的左侧,一张用于窗帘的右侧(以红色表示)。我想用核心动画顺利地将它们滑走。我应该寻找什么类型的动画?如何实现逼真的滑动风格? 问候, 斯特凡 a
我有一个简单的旋转动画,可以让一个对象绕其轴旋转。目前它旋转得太快了,我想减慢速度,我试过增加样本??但我对动画了解不多,所以我可能过得很好。如何放慢动画速度?它只有两个键。 最佳答案 首先,通过双击
我似乎无法在上类时获得 angularjs ng-animate,而且在野外似乎也没有任何示例。以演示 fiddle 为例: http://jsfiddle.net/yfajy/ 向 CSS 添加如下
使用以下代码段:http://jsfiddle.net/sylouuu/V7a3Y/2/ 我想在动画的#log 中显示从 0% 到 100% 的进度百分比,100% 很容易通过回调... 有可能这样做
我正在 HTML 中使用 SVG 来使用折线工具定义特定的形状。我希望通过按一下按钮并在几秒钟内将特定形状的外观动画化为不同的形状。 我一直在考虑使用动画工具来更改折线点属性,但到目前为止一直无法找到
您好,在 Firefox(相当糟糕)和 Chrome 之间获得可变性能和效果(还可以)有时这不会执行第一个动画,有时会卡住。 我的结构正确吗? $notification.animate({
我在 iOS 编程时遇到了一个问题:当我尝试为我的 tableView 制作自定义编辑按钮时,我无法将其设置为动画。下面是我如何初始化 tableview: - (void)viewWillAppea
自 beta 5 以来,我注意到在 OS X 10.10 下隐式动画有一些奇怪的行为。调用动画代理有时会导致应用程序崩溃。我设置了一个非常简单的自定义 View 。这是完整的代码: import Co
我正在开发一个可折叠组件,您可以单击它来向上/向下滚动以显示/隐藏详细信息。组件如下: // component.ts import {Component, Directive, Input} fro
我正在努力了解 web animations standard和他们的 polyfill ,正如我所见,它在 Angular 动画库中运行良好(您将动画结束值设置为“*”,这将变为 div 大小的 1
我想创建一个动画闪屏,但出现此错误: Android.Content.Res.Resources+NotFoundException: File res/drawable/splash_screen.
我正在尝试对我的应用程序应用慢动作效果,就像按 Shift 时如何减慢 Mac OS 的大多数图形效果一样。 我的应用程序使用 CoreAnimation,所以我认为它应该没什么大不了的:set sp
我想以编程方式同时不在XML文件中显示两个动画,它应该 ROTATE和TRANSLATE 我怎样才能做到这一点? 请以某种方式建议我?????? 这是ma代码:> ImageView snowImg1
我是一名优秀的程序员,十分优秀!