我一直在用 CoffeeScript 编写代码,因为我一直在用它编写 React。
这是基本结构。
{ div, input } = React.DOM
Outer = React.createClass
render: ->
div { id: 'myApp' },
Inner()
Inner = React.createClass
render: ->
input { id: 'myInput', ref: 'myInput' }
toggle
我的外部类有一个方法,它是通过按快捷方式触发的。它切换我的应用程序的可见性。
当我的应用程序从隐藏切换到显示时,我想专注于输入。
现在切换方法看起来或多或少是这样的:
Outer = React.createClass
render: ->
......
hide: ->
@setState { visible: no }
show: ->
@setState { visible: yes }
$('#myInput').focus() # jQuery
# I want to do something like
# @refs.myInput.getDOMNode().focus()
# But @refs here is empty, it doesn't contain the refs in Inner
toggle: ->
if @state.visible
@hide()
else
@show()
那我该怎么做呢?