我知道这个问题在 SO 中可能已被问过数百万次,但我已经尝试了大部分解决方案,我只是不知道为什么它对我不起作用。
所以我有一个下拉列表,其中 display 最初针对 none。当我点击它时,它显示了很好的过渡。 (到目前为止,一切都很好)。但是,当我再次单击它以隐藏下拉菜单时,它会立即隐藏,但我不希望那样。我想隐藏与分配给显示的类似过渡。这是我的 CSS 代码:
.dropdown-menu {
padding: 0 0;
display: none;
-webkit-animation: slide-down .3s ease-out;
-moz-animation: slide-down .3s ease-out;
}
.table-dropdown-open {
display: block;
-webkit-animation: slide-down .3s ease-out;
-moz-animation: slide-down .3s ease-out;
}
@-webkit-keyframes slide-down {
0% {
opacity: 0;
-webkit-transform: translateY(-10%);
}
100% {
opacity: 1;
-webkit-transform: translateY(0);
}
}
@-moz-keyframes slide-down {
0% {
opacity: 0;
-moz-transform: translateY(-10%);
}
100% {
opacity: 1;
-moz-transform: translateY(0);
}
}
这不是重复 Action ,因为我试图将 block 转换为
无。不是从 none 到 block
最佳答案
始终显示您的元素,并且仅transition任何可动画属性。在您的情况下, opacity 看起来是个不错的选择,尽管使用 transform 也可能会给您带来理想的结果。简单的例子:
any {
transform: scale(0);
transition: transform .4s cubic-bezier(.5,0,.3,1);
}
any.animated {
transform: scale(1);
}
实际上,opacity 和 transform 应该是您应该设置动画的仅有的两个属性,因为它们不需要 DOM 重绘任何东西除了动画元素,因此不会影响浏览器性能,即使您同时为大量元素设置动画也是如此。
请注意,即使没有绘制,您的元素实际上也位于它们根本没有transform时所在的位置。因此,当它们处于"invisible" 状态时,您可能希望为它们提供 pointer-events:none,而当它们处于pointer-events:all 时处于“可见”状态,因此它们在不可见时不会捕获任何指针事件。
考虑到您的示例,我已经为您提供了两个动画示例(带关键帧和不带关键帧)。记住你需要 prefix your code .为了完全兼容浏览器,请在设置(底部的小框)中使用 > 0%。
setTimeout(function(){
var dm = document.querySelector('.dropdown-menu');
dm.classList.remove('hide-menu');
}, 300);/* simple animation example, on parent. No keyframes. */
.dropdown-menu.hide-menu {
opacity: 0;
}
.dropdown-menu {
opacity: 1;
transition: opacity .2s cubic-bezier(.4,0,.2,1);
position: relative;
animation: delay-overflow .3s;
animation-fill-mode: forwards;
animation-iteration-count: 1;
}
.dropdown-menu:hover {
animation: none;
cursor: pointer;
}
/* animation example with keyframes, on child */
.dropdown-menu ul {
position: absolute;
margin-top: 0;
padding-top: 1rem;
top: 100%;
opacity: 0;
transform: translateY(-10%);
animation: slide-up .3s;
animation-fill-mode: forwards;
animation-iteration-count: 1;
}
.drowdown-menu.hide-menu ul {
animation-duration: 0s;
}
.dropdown-menu:hover ul {
animation: slide-down .3s;
animation-fill-mode: forwards;
}
@keyframes slide-down {
from {
opacity: 0;
transform: translateY(-10%);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@keyframes slide-up {
from {
opacity: 1;
transform: translateY(0);
}
to {
opacity: 0;
transform: translateY(-10%);
}
}
@keyframes delay-overflow {
0% {
overflow: visible;
}
99% {
overflow: visible;
}
100% {
overflow: hidden;
}
}<div class="dropdown-menu hide-menu">
<span>Menu</span>
<ul>
<li>A menu item</li>
<li>Another menu item</li>
<li>...</li>
<li>And so on...</li>
</ul>
</div>
注意:animation 属性的一个非常方便的技巧是它允许您延迟应用任何属性,即使是不可动画的属性也可以延迟应用所需的时间.我正在使用这个技巧来延迟 overflow:hidden 应用于父级(并且 overflow 不可设置动画)所以子级的动画 - 这发生在parent - 直到最后都是可见的。完成后,应用 overflow:hidden 并且它不再捕获菜单打开器之外的鼠标事件。
关于html - 从不显示到显示 block 的 CSS 转换,反之亦然,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42414565/
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h
我得到了一个包含嵌套链接的表单。编辑时链接字段为空的问题。这是我的表格:Editingkategori{:action=>'update',:id=>@konkurrancer.id})do|f|%>'Trackingurl',:style=>'width:500;'%>'Editkonkurrence'%>|我的konkurrencer模型:has_one:link我的链接模型:classLink我的konkurrancer编辑操作:defedit@konkurrancer=Konkurrancer.find(params[:id])@konkurrancer.link_attrib
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]
我在MiniTest::Spec和Capybara中使用以下规范:find_field('Email').must_have_css('[autofocus]')检查名为“电子邮件”的字段是否具有autofocus属性。doc说如下:has_css?(path,options={})ChecksifagivenCSSselectorisonthepageorcurrentnode.据我了解,字段“Email”是一个节点,因此调用must_have_css绝对有效!我做错了什么? 最佳答案 通过JonasNicklas得到了答案:No
这道题是thisquestion的逆题.给定一个散列,每个键都有一个数组,例如{[:a,:b,:c]=>1,[:a,:b,:d]=>2,[:a,:e]=>3,[:f]=>4,}将其转换为嵌套哈希的最佳方法是什么{:a=>{:b=>{:c=>1,:d=>2},:e=>3,},:f=>4,} 最佳答案 这是一个迭代的解决方案,递归的解决方案留给读者作为练习:defconvert(h={})ret={}h.eachdo|k,v|node=retk[0..-2].each{|x|node[x]||={};node=node[x]}node[
我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere
在我的Controller中,我通过以下方式在我的index方法中支持HTML和JSON:respond_todo|format|format.htmlformat.json{renderjson:@user}end在浏览器中拉起它时,它会自然地以HTML呈现。但是,当我对/user资源进行内容类型为application/json的curl调用时(因为它是索引方法),我仍然将HTML作为响应。如何获取JSON作为响应?我还需要说明什么? 最佳答案 您应该将.json附加到请求的url,提供的格式在routes.rb的路径中定义。这
所以我在关注Railscast,我注意到在html.erb文件中,ruby代码有一个微弱的背景高亮效果,以区别于其他代码HTML文档。我知道Ryan使用TextMate。我正在使用SublimeText3。我怎样才能达到同样的效果?谢谢! 最佳答案 为SublimeText安装ERB包。假设您安装了SublimeText包管理器*,只需点击cmd+shift+P即可获得命令菜单,然后键入installpackage并选择PackageControl:InstallPackage获取包管理器菜单。在该菜单中,键入ERB并在看到包时选择