- objective-c - iOS 5 : Can you override UIAppearance customisations in specific classes?
- iphone - 如何将 CGFontRef 转换为 UIFont?
- ios - 以编程方式关闭标记的信息窗口 google maps iOS
- ios - Xcode 5 - 尝试验证存档时出现 "No application records were found"
我有一个函数,它使用 jQuery 将 html 加载到一个表中,然后使用回调将一个类添加到其中一行。该功能由页面上的各种 UI 驱动事件触发。我还有一个 css 过渡规则,所以颜色应该淡入(transition: background-color 1000ms linear
)。该函数如下所示:
function load_tbody(row_id) {
$('tbody').load("load_tbody.php", function() {
$(row_id).addClass('green');
});
}
加载 html 后,类成功添加,行颜色设置为绿色。但是,我的 css 转换规则似乎被忽略了。
当我添加一个轻微的延迟时,即使是 10 毫秒,它也能正常工作:
function load_tbody(row_id) {
$('tbody').load("load_tbody.php", function() {
setTimeout(function() {
$(row_id).addClass('green');
}, 10);
});
}
If a "complete" callback is provided, it is executed afterpost-processing and HTML insertion has been performed.
对我而言,这表明新元素已加载到 dom 中并应用了现有样式并准备好进行操作。为什么转换在第一个示例中失败但在第二个示例中成功?
这是一个功能齐全的示例页面,用于演示相关行为:
http://so-37035335.dev.zuma-design.com/
虽然上面的示例从 cdn 链接 jQuery 2.2.3 版,但实际页面使用的是 1.7.1 版。在两个版本中都可以观察到相同的行为。
更新:
在考虑了下面提供的一些评论和答案之后,我偶然发现了一些更令人困惑的事情。用户@gdyrrahitis 提出的建议促使我这样做:
function tbody_fade(row_id) {
$('tbody').load("load_tbody.php", function() {
$('tbody').fadeIn(0, function() {
$(this).find(row_id).addClass('green');
});
});
}
在 fadeIn()
回调中添加类是有效的,即使持续时间为 0ms。所以这让我想知道......如果该元素理论上无论如何都存在,那么在我添加该类之前浏览器认为它具有什么背景颜色。所以我记录了 background-color
:
console.log($(row_id).css('background-color'));
你知道吗?只需获取背景色颜色即可使一切正常:
function tbody_get_style(row_id) {
$('tbody').load("load_tbody.php", function() {
$(row_id).css('background-color');
$(row_id).addClass('green');
});
}
只需添加 $(row_id).css('background-color');
这行看似什么都不做就会导致过渡效果起作用。这是一个演示:
http://so-37035335-b.dev.zuma-design.com/
看到这里,我简直傻眼了。为什么这行得通?它只是增加了一个小的延迟,还是 jQuery 获取 css 属性以某种方式对新添加元素的状态产生了实质性影响?
最佳答案
jQuery load
旨在将请求的所有内容放入页面。
您可以通过使用 $.get
来利用 jQuery Deferred
对象的强大功能。
看看这个plunk .
来自 plunk 的代码片段
function load_tbody(row_id) {
$.when($.get("load_tbody.html", function(response) {
$('tbody').hide().html(response).fadeIn(100, function() {
$(this).find(row_id).addClass('green');
});
}));
}
我正在使用 $.when
它将在 $.get
解析后立即运行其回调,这意味着将获取 HTML 响应。获取响应后,它被附加到 tbody
,它是 fadedIn(fadeIn
方法),显示后,.green
类被添加到所需的行。
请注意,如果您只是将 html 和类附加到 row_id
,您将看不到转换,因为它会立即执行。使用 fadeIn
的一些漂亮的视觉技巧可以完成这项工作。
更新
在 DOM 中新添加的元素上,不会触发 CSS3 transition
。这主要是因为控制所有动画的内部浏览器引擎。有许多关于该问题的解决方法的文章,以及 stackoverflow 的答案。可以在那里找到其他资源,我相信这些资源可以比我更好地解释这个主题。
这个答案是关于退后一步并更改在 DOM 中呈现动态元素的功能部分,而无需使用 setTimeout
或 requestAnimationFrame
。这只是以清晰一致的方式实现您想要实现的目标的另一种方式,因为 jQuery 可以跨浏览器工作。 fadeIn(100, ...
是 catch 浏览器即将渲染的下一个可用帧所需要的。它可能会少得多,该值只是为了满足视觉美感。
另一种解决方法是完全不使用过渡,而是使用animation
。但根据我的测试,这在 IE Edge 中失败了,在 Chrome、Firefox 上运行良好。
请查看以下资源:
更新 2
看看 specification拜托,因为那里有关于 CSS3 transitions
的有趣内容。
...This processing of a set of simultaneous style changes is called a style change event. (Implementations typically have a style change event to correspond with their desired screen refresh rate, and when up-to-date computed style or layout information is needed for a script API that depends on it.)
Since this specification does not define when a style change event occurs, and thus what changes to computed values are considered simultaneous, authors should be aware that changing any of the transition properties a small amount of time after making a change that might transition can result in behavior that varies between implementations, since the changes might be considered simultaneous in some implementations but not others.
When a style change event occurs, implementations must start transitions based on the computed values that changed in that event. If an element is not in the document during that style change even or was not in the document during the previous style change event, then transitions are not started for that element in that style change event.
关于javascript - CSS Transition 在 jQuery .load 回调上失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37035335/
我有一个名为 main.css 的 css 文件和另一个名为 style.css 的文件。我怎样才能在 main.css 中做到这一点? .someClass { //apply rules to
在更新我的 css 之前,我在 Login.css 中有以下内容: body { background-image: url('./pictures/fond.png'); bac
我的 share point 2013 核心 css 和我的 css 之间存在 css 冲突。所以我想把我所有的类都放在 div #s4-workspace 下但是我搜索了一种方法来将所有类分组到这个
我知道您可以覆盖 jsp 页面从 jsp 包含 CSS 文件(即全局 CSS 文件)继承的 CSS 属性。 但是,如果元素中的某个属性弄乱了特定页面,而我不想只使用内联 CSS 在该页面中使用它怎么办
我刚刚发现了 initial-scale 元属性。 以前,我一直在使用 default.css 来定义我所有的样式和大小(用于字体和元素),以便它们在桌面计算机的屏幕上显示得很好。然后,如果您使用的是
我正在尝试使用 LESS CSS 来编写我的 CSS。我已经按顺序导入了 style.less 和 less.js 文件。 现在我想提取 LESS 生成的 CSS。有什么办法可以做到吗?我不想使用脚本
我想知道是否有任何一种软件可以读取大量内联样式中的 HTML 文档并将所有这些样式转换为外部 css 文件。如果只有一页,我可以手动完成。但是有100页。有人有想法吗? 最佳答案 就像有人说的那样,“
当我想从 Styled Components 迁移到 CSS Modules 时,出现了以下问题。 假设我有以下样式组件,它接受动态参数 offset和一个动态 CSS 字符串 theme : con
有没有办法将 CSS 类定义为与另一个类相等?例如,如果我有一个类: .myClass{ background-color: blue; } 有没有一种方法可以将第二个类定义为与 myClas
我正在尝试制作一组按钮,这些按钮贴在页面底部并且由固定的空间隔开。我正在使用 angularJS 的 ng-repeat 指令通过 ajax 请求获取数据,然后我用它来显示按钮。 我的问题在于让按
浏览器是否在加载 CSS 文件时解析 CSS?还是在整个 CSS 文件被浏览器下载后才进行解析?不同浏览器的做法有区别吗?我在哪里可以找到这种底层信息? 这个问题不是 Load and executi
这个问题在这里已经有了答案: Can a CSS class inherit one or more other classes? (29 个答案) 关闭 3 年前。 标题有点乱,我给大家看一下。假
我遇到了最奇怪的问题...... 在最简单的形式中,我有一个包含以下内容的 index.html 文件: (在尝试确定根本原因的过程中,我已经大大减少了它) 当我查看页面的源代码时,我得到以下信息:
我正在使用 Mindscape Workbench 来最小化我的 scss 文件。我的页面设置为使用 *.min.css 文件。在随机时间,min 文件不会与系统的其余部分一起发布。 我有很多 css
请告诉我 CSS 框架和 CSS 网格之间的区别。 最佳答案 CSS 框架也可以是 CSS 网格框架。 CSS 网格框架用于构建 CSS 布局。有一些框架除了构建布局还有其他用途,例如 Hartija
我有无法从页面中删除或更改的 original.css 文件。原始.css table { border-collapse: collapse; border-spacing: 0;
我以前使用 bootstrap css import 很好。 但是我正在尝试使用 CSS 模块,所以我添加了几行。 { test: /\.css$/, use:
有没有办法在 css 选择器中创建一个 css 组。 例如: .SectionHeader { include: .foo; include: .bar; include: .
今天我学习了 CSS 中的两个概念,一个是 CSS 定位(静态、相对、绝对、固定),另一个是 CSS Margin,它定义了元素之间的空间。 假设我想移动一个元素,这是最好的方法吗?因为这两个概念似乎
var paths = { css: './public/apps/user/**/*.css' } var dest = { css: './public/apps/user/css/' } /
我是一名优秀的程序员,十分优秀!