- 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"
我有一个菜单,一旦按下汉堡包图标,它就会显示在当前页面的顶部,它使用 Glamor for CSS。
菜单从屏幕右侧进入动画并且工作完美,但是我很难让它在按下菜单中的任何位置后动画出来。
动画已编写 (animateOut),但我需要有关代码的帮助,以根据点击在动画进出之间轻弹:
汉堡菜单.js
CSS
const cssHamburgerMenuIcon = css({
position: 'absolute',
height: 20,
width: 20,
right: 20,
marginTop: 20,
})
const animateIn = css.keyframes({
'0%': {
transform: 'translateX(100%)'
},
'100%': {
transform: 'translateX(0%)'
}
})
const animateOut = css.keyframes({
'0%': {
transform: 'translateX(0%)'
},
'100%': {
transform: 'translateX(100%)'
}
})
const cssHamburgerMenu = css({
display: 'flex',
position: 'absolute',
flexDirection: 'column',
height: '100%',
width: 250,
right: 0,
top: 0,
zIndex: 1,
color: 'white',
backgroundColor: hamburgerGrey,
fontFamily: 'Century Gothic',
fontSize: '19px',
// animation
animation: `${animateIn} 0.5s`,
})
const cssHamburgerList = css({
listStyleType: 'none',
lineHeight: '47px',
})
const cssHamburgerListItem = css({
})
“代码”
class HamburgerMenu extends Component {
constructor(props) {
super(props)
this.state = {
menuVisible: false,
}
}
render() {
const menuVisible = this.state.menuVisible
return(
menuVisible ?
<div className={cssHamburgerMenu} onClick={() =>this.setState({ menuVisible: false })}>
<ul className={cssHamburgerList}>
<li className={cssHamburgerListItem}>Home</li>
<li className={cssHamburgerListItem}>News</li>
<li className={cssHamburgerListItem}>About us</li>
<li className={cssHamburgerListItem}>More</li>
</ul>
</div>
: (
<img
className={cssHamburgerMenuIcon}
src={HamburgerMenuIcon}
onClick={() => this.setState({ menuVisible: true})
}
/>
)
)
}
}
export default HamburgerMenu
最佳答案
我建议另一种方法:
将菜单的默认 translateX 设置为 100%
创建一个将 translateX 设置为 0% 的类(即 open)
设置菜单的过渡属性为“transition: all 0.5s ease-in-out;”
只需在需要打开/关闭菜单时添加或删除 (open) 类
关于html - 使用 CSS 制作进出动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49155444/
我是 Java 新手。我在学校有这个练习来创建一个 BasicIO 类和 Main 类来读取和写入文件。 但是我的代码只读取第一句并在无限循环中打印它。 基本IO.java import java.i
我在处理几个正则表达式时遇到了一些麻烦,我之前差点就开始工作了。我基本上需要删除特定 两边的 HTML 注释标签。 这是我目前所拥有的: .replace(/-->/, 'oncl
我正在使用下面的代码将一个 div 部分切换出屏幕,然后完全切换回屏幕。此代码告诉“侧边栏”要移出屏幕多远。但在我的例子中,由于媒体查询应用于侧边栏宽度,此功能存在问题。因此,我需要的代码不是说明侧边
我找不到有关在一段时间内(例如一秒)应向 Firebase 数据库(或类似数据库)发送的最大消息数以及应用程序可以处理接收的最大消息数的最佳实践文档没有显着放缓。例如: //send updated
我在使我的 div 从右侧 float 到屏幕的 50% 时遇到问题,我似乎无法弄清楚为什么它不起作用。 myFunction = function() { var divPosition = $
我们如何知道 cocoapods 是否已安装?在我们的 MAC 中?安装时我将其输出到终端: ERROR: While executing gem ... (NoMethodError) undefi
我正在我的 ubuntu 系统上使用 anaconda 构建深度学习环境。 我对 Anaconda 完全陌生。 我创造了一个环境 conda create -n darkflow python=3.6
是否有可能有效地向 CUDA 设备或从 CUDA 设备复制以恒定(甚至非常量)值跨越的数据? 我想对角化一个大的对称矩阵。 使用 jacobi 算法,在每次迭代中有一堆使用两行和两列的操作。 由于 M
如果我想将数据发送给所有连接的人,是否应该将 redis 订阅事件放在 io.connect 回调之外?或者像这样将它放在 io.connect 中更好: io.on('connection'
我有一些正在序列化的数据。我需要在 .Net 3.5(还不是 4.0)下使用 ADO.NET(也使用企业库)从 VarBinary 列保存和恢复它。 我似乎能够找到并开始工作的唯一接口(interfa
我是一名优秀的程序员,十分优秀!