Skip to content

搞英语 → 看世界

翻译英文优质信息和名人推特

Menu
  • 首页
  • 作者列表
  • 独立博客
  • 专业媒体
  • 名人推特
  • 邮件列表
  • 关于本站
Menu

检测剪贴板中的内容类型

Posted on 2023-03-06

用户的剪贴板是操作系统和其上使用的应用程序之间的“全部”。当您使用网络浏览器时,您可以突出显示文本或右键单击图像并选择“复制图像”。这让我开始思考开发人员如何检测剪贴板中的内容。

您可以使用navigator.clipboard API 检索用户剪贴板的内容。此 API 需要用户许可,因为剪贴板可能包含敏感数据。您可以使用以下 JavaScript 获取使用剪贴板 API 的权限:

  
const result = await navigator.permissions.query({name: "clipboard-write"});  
if (result.state === "granted" || result.state === "prompt") {  
  // 剪贴板权限可用  
}  

授予剪贴板权限后,您可以查询剪贴板以获取ClipboardItem实例,其中包含已复制内容的详细信息:

  
const [item] = await navigator.clipboard.read();  
  
// 当文本被复制到剪贴板时....  
item.types // ["text/plain"]  
  
// 当从网站复制图像时...  
item.types // ["text/html", "image/png"]  

一旦知道内容和 MIME 类型,就可以使用readText()获取剪贴板中的文本:

  
const content = await navigator.clipboard.readText();  

对于图像,如果您有可用的 MIME 类型和内容,则可以使用带有数据 URI 的<img>进行显示。准确呈现用户复制的内容时,了解用户剪贴板的内容会很有帮助!

检测剪贴板中的内容类型一文首先出现在David Walsh 博客上。

原文: https://davidwalsh.name/detect-clipboard-content

本站文章系自动翻译,站长会周期检查,如果有不当内容,请点此留言,非常感谢。
  • Abhinav
  • Abigail Pain
  • Adam Fortuna
  • Alberto Gallego
  • Alex Wlchan
  • Answer.AI
  • Arne Bahlo
  • Ben Carlson
  • Ben Kuhn
  • Bert Hubert
  • Bits about Money
  • Brian Krebs
  • ByteByteGo
  • Chip Huyen
  • Chips and Cheese
  • Christopher Butler
  • Colin Percival
  • Cool Infographics
  • Dan Sinker
  • David Walsh
  • Dmitry Dolzhenko
  • Dustin Curtis
  • Elad Gil
  • Ellie Huxtable
  • Ethan Marcotte
  • Exponential View
  • FAIL Blog
  • Founder Weekly
  • Geoffrey Huntley
  • Geoffrey Litt
  • Greg Mankiw
  • Henrique Dias
  • Hypercritical
  • IEEE Spectrum
  • Investment Talk
  • Jaz
  • Jeff Geerling
  • Jonas Hietala
  • Josh Comeau
  • Lenny Rachitsky
  • Liz Danzico
  • Lou Plummer
  • Luke Wroblewski
  • Matt Baer
  • Matt Stoller
  • Matthias Endler
  • Mert Bulan
  • Mostly metrics
  • News Letter
  • NextDraft
  • Non_Interactive
  • Not Boring
  • One Useful Thing
  • Phil Eaton
  • Product Market Fit
  • Readwise
  • ReedyBear
  • Robert Heaton
  • Ruben Schade
  • Sage Economics
  • Sam Altman
  • Sam Rose
  • selfh.st
  • Shtetl-Optimized
  • Simon schreibt
  • Slashdot
  • Small Good Things
  • Taylor Troesh
  • Telegram Blog
  • The Macro Compass
  • The Pomp Letter
  • thesephist
  • Thinking Deep & Wide
  • Tim Kellogg
  • Understanding AI
  • 英文媒体
  • 英文推特
  • 英文独立博客
©2025 搞英语 → 看世界 | Design: Newspaperly WordPress Theme