首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使用相同的热键打开和关闭模式

如何使用相同的热键打开和关闭模式
EN

Stack Overflow用户
提问于 2014-01-29 00:04:23
回答 1查看 73关注 0票数 0

我试图用相同的热键打开和关闭模态窗口:

代码语言:javascript
运行
复制
if !$('#new-stuff').length or $('#new-stuff').is(':hidden')
  $(document).keydown( (e) ->
    if e.altKey && e.which == 65
      e.preventDefault
      modal.open(
        content: '<input type="text" placeholder="New stuff here!" id="new-stuff"><br /><input type="submit" value="Do stuff!">'
      )
  ).keyup( ->
    $('#new-stuff').focus()
  )
else
  $(document).keyup( (e) ->
    if e.altKey && e.which == 65
      e.preventDefault()
      modal.close()
  )

当我按下alt + A模式是开放的,重点是输入。但是当我再次按alt + A时,它会再次关注输入,而不是关闭。

代码语言:javascript
运行
复制
!$('#new-stuff').length or $('#new-stuff').is(':hidden')

两者都是false,但$('#new-stuff').focus()正在发生。为什么?

和如何用alt + A关闭模态

更新

以下是工作代码:

代码语言:javascript
运行
复制
$(document).keydown( (e) ->
  if e.altKey && e.which == 65
    if $('#new-stuff').is(':visible')
      e.preventDefault()
      modal.close()
    else
      e.preventDefault
      modal.open(
        content: '<input type="text" placeholder="New stuff here!" id="new-stuff"><br /><input type="submit" value="Do stuff!">'
      )
).keyup( ->
  $('#new-stuff').focus() if $('#new-stuff').is(':visible')
)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-01-29 00:21:04

看起来,您需要将条件放在事件函数中。就像这样:

代码语言:javascript
运行
复制
$(document).keyup( (e) ->
  if e.altKey && e.which == 65
    if $('#new-stuff:visible)')
      # hide it
    else
      # show it
 )
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21419520

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档