当前位置: 首页 > 面试题库 >

Trello如何访问用户的剪贴板?

后焕
2023-03-14
问题内容

当您将鼠标悬停在Trello中的卡片上并按Ctrl+时C,该卡片的URL被复制到剪贴板。他们如何做到这一点?

据我所知,没有涉及Flash电影。我已经安装了Flashblock,并且Firefox的“网络”标签显示未加载Flash电影。(这是通常的方法,例如,ZeroClipboard。)

他们如何实现这种魔力?

(目前,我想我顿悟了:您无法选择页面上的文本,因此我假设它们具有不可见的元素,它们通过JavaScript代码创建文本选择,并Ctrl+
C触发浏览器的默认行为,复制该不可见的元素节点的文本值。)


问题答案:

披露:
我写了Trello使用的代码;下面的代码是Trello用于完成剪贴板技巧的实际源代码。

我们实际上并没有“访问用户的剪贴板”,而是通过在用户按Ctrl+ 时选择一些有用的东西来帮助用户C

听起来您已经解决了;我们利用了这样一个事实,当您想按Ctrl+时C,您必须先Ctrl按键。当Ctrl按下键时,我们会弹出一个文本区域,其中包含我们要在剪贴板上结束的文本,并选择其中的所有文本,因此当C按下键时,所有选择都已设置。(然后,当Ctrl按键出现时,我们将隐藏文本区域)

具体来说,Trello这样做:

TrelloClipboard = new class
  constructor: ->
    @value = ""

    $(document).keydown (e) =>
      # Only do this if there's something to be put on the clipboard, and it
      # looks like they're starting a copy shortcut
      if !@value || !(e.ctrlKey || e.metaKey)
        return

      if $(e.target).is("input:visible,textarea:visible")
        return

      # Abort if it looks like they've selected some text (maybe they're trying
      # to copy out a bit of the description or something)
      if window.getSelection?()?.toString()
        return

      if document.selection?.createRange().text
        return

      _.defer =>
        $clipboardContainer = $("#clipboard-container")
        $clipboardContainer.empty().show()
        $("<textarea id='clipboard'></textarea>")
        .val(@value)
        .appendTo($clipboardContainer)
        .focus()
        .select()

    $(document).keyup (e) ->
      if $(e.target).is("#clipboard")
        $("#clipboard-container").empty().hide()

  set: (@value) ->

在DOM中,

<div id="clipboard-container"><textarea id="clipboard"></textarea></div>

剪贴板内容的CSS:

#clipboard-container {
  position: fixed;
  left: 0px;
  top: 0px;
  width: 0px;
  height: 0px;
  z-index: 100;
  display: none;
  opacity: 0;
}
#clipboard {
  width: 1px;
  height: 1px;       
  padding: 0px;
}

…,而CSS做到了这一点,因此当它弹出时,您实际上看不到textarea,但是它的“可见”程度足以复制。

当您将鼠标悬停在卡片上时,它会呼叫

TrelloClipboard.set(cardUrl)

…因此剪贴板助手会在Ctrl按下键时知道选择什么。



 类似资料:
  • 问题内容: 我想从Java中的系统剪贴板中粘贴。我该怎么做? 问题答案: 尽管机器人类可以工作,但它不像直接使用系统剪贴板那样优雅,例如:

  • 在系统剪贴板上执行复制和剪贴操作 进程: 主进程, 渲染进程​ 复制字符串例子: 1 const {clipboard} = require('electron') 2 clipboard.writeText('Example String') Copied! 在X Window系统上,还有一个选择剪贴板。要操作它,你需要传递selection到每个方法: 1 const {clipboard}

  • 在系统剪贴板上执行复制和粘贴操作。 进程: Main, Renderer 下面的示例演示如何将字符串写入剪贴板: const { clipboard } = require('electron') clipboard.writeText('Example String') On Linux, there is also a selection clipboard. To manipulate it

  • 问题内容: 我了解,粗略地说,Trello使用Redis进行临时数据存储。 有谁能够进一步详细说明它在应用程序中扮演的角色? 问题答案: 我们在Trello上使用Redis 来存储临时数据,这样就不会丢失。我们不会将Redis中的数据持久化到磁盘上,而是使用allkeys- lru ,因此我们只存储可以随时踢出的内容,给用户带来的不便很小(例如,暂时看到错误的用户状态)。话虽这么说,我们为它提供了

  • 问题内容: 我是Linux用户,经常需要通过SSH在远程OS X服务器上工作。我更喜欢vim(neovim)编辑器,但是我在通过SSH复制/粘贴到系统剪贴板中时遇到问题。当我尝试复制行时,它将保存在远程OS X剪贴板上。有没有办法将其保存到我的Linux剪贴板中? 问题答案: 基本上,您可以在Linux机器上打开远程文件,例如: 直接从ssh会话复制的另一种解决方案是ssh中的X11转发,它将连接

  • Microsoft Windows剪贴簿允许把数据从一个程序传送到另一个程序中。它的原理相对而言比较简单,把数据存放到剪贴簿上的程序或从剪贴簿上取出数据的程序都无须太多的负担。Windows 98和Microsoft Windows NT都提供了剪贴簿浏览程序,该程序可以显示剪贴簿的目前内容。 许多处理文件或者其它数据的程序都包含一个「Edit」菜单,其中包括「Cut」、「Copy」和「Paste