JS implements pasteboard copy function code sharing
Using the clipboard is an essential skill. As a coder, everyone should know that Tab, Ctrl/Cmd + A, Ctrl/Cmd + C and Ctrl/Cmd + V are shortcut keys for auto-focus, copy and paste respectively.
But it may not be easy for ordinary users. Even if a user knows what a clipboard is, it will be difficult to highlight the exact text they want (except for) those with great eyesight or quick reflexes. If the user doesn't know the keyboard shortcuts, can't see the hidden editing menu, has never used the right-click menu, or doesn't know that long-pressing the touch screen brings up the options menu, then he will probably not be aware of the copy function.
So should we provide a "Copy to Clipboard" button to help the user? This feature should be useful even for users who are very familiar with keyboard shortcuts.
About clipboard security
A few years ago, it was impossible for browsers to use the clipboard directly. Developers had to implement it through Flash.
The clipboard may seem inconsequential, but imagine what would happen if the browser could see and manipulate the content at will. JS scripts (including third-party scripts) can view the text information in the clipboard and send passwords, sensitive information, or even entire documents to the remote server.
The current clipboard has limited basic functions and has the following restrictions:
Most browsers support the clipboard, except Safari.
Support varies by browser, and some features are incomplete or problematic.
Events must be initiated by the user, such as clicking the mouse or pressing the keyboard. The script does not have free access to the clipboard.
document.execCommand()
This method is the key to implementing the clipboard, it can pass in cut, copy, paste three parameters. Let’s start with the most commonly used document.execCommand('copy')
.
Before using, we should check whether the browser supports the copy command: document.queryCommandSupported('copy');
or document.queryCommandEnabled('copy');
, these two methods have the same effect.
But under Chrome, although Chrome does support the use of copy naming, both methods return false. So it's better to wrap the checking code in a try-catch block.
Next step, what should we allow users to copy? Text must be highlighted, and all browsers can use the select() method to select text within text input and textarea. At the same time, Firefox and Chrome/Opera also support the document.createRange
method, which allows text selection from any element, as follows:
// select text in #myelement node var myelement = document.getElementById('#myelement'), range = document.createRange(); range.selectNode(myelement); window.getSelection().addRange(range);
But IE/ Edge does not support it.
clipboard.js
If you don’t want to implement a more robust cross-browser clipboard method yourself, clipboard.js can help you. It has several ways to set options, such as H5's data attribute, setting binding trigger elements and target elements, such as:
<input id="copyme" value="text in this field will be copied" /> <button data-clipboard-target="#copyme">copy</button>
Do it yourself
The size of clipboard.js is only 2Kb. If only some of the following functions are implemented, it can be implemented within 20 lines of code:
Only some form elements can be copied
If in an unsupported browser (yes, Safari), you can highlight the selected text and prompt the user to press Ctrl/Cmd + C.
Like clipboard.js, first create a button to trigger the method. It has a data attribute data-copytarget, pointing to the element to be copied (i.e. #website)
<input type="text" id="website" value="http://www.sitepoint.com/" /> <button data-copytarget="#website">copy</button> 一个立即执行函数表达式绑定click事件的函数,该函数用于解析 data-copytarget 属性内容,选择对应字段的文本并执行 document.execCommand('copy') ,。若失败,文本保持选中状态,显示提示框: (function() { 'use strict'; // click events document.body.addEventListener('click', copy, true); // event handler function copy(e) { // find target element var t = e.target, c = t.dataset.copytarget, inp = (c ? document.querySelector(c) : null); // is element selectable? if (inp && inp.select) { // select text inp.select(); try { // copy text document.execCommand('copy'); inp.blur(); } catch (err) { alert('please press Ctrl/Cmd+C to copy'); } } } })();
Example
Although in the above example, including the code for styles and animations, the code has exceeded 20 lines, animations and styles are optional.
Summary:
Select the content of the form element to be copied through .select()
Call document.execCommand( "copy") method
Call the .blur() method to remove focus from the form element
Include steps 2 and 3 In the try catch block, if the browser does not support it, it will prompt
Other ways
There are many novel clipboards Application method. For example, Trello.com, when hovering over a card, you can press Ctrl / Cmd + C
and copy the card's link address to your clipboard. The implementation behind it is to first create a hidden form element containing the URL, then select and copy its content. Very clever and useful - I suspect very few users know about this feature!
Related recommendations:
js implements the function code of copying to the pasteboard_basic knowledge
JavaScript implements the code of copying content to the pasteboard _javascript skills
js method of clicking on an image to copy the image address to the pasteboard_javascript skills
The above is the detailed content of JS implements pasteboard copy function code sharing. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

There will be many AI creation functions in the Doubao app, so what functions does the Doubao app have? Users can use this software to create paintings, chat with AI, generate articles for users, help everyone search for songs, etc. This function introduction of the Doubao app can tell you the specific operation method. The specific content is below, so take a look! What functions does the Doubao app have? Answer: You can draw, chat, write articles, and find songs. Function introduction: 1. Question query: You can use AI to find answers to questions faster, and you can ask any kind of questions. 2. Picture generation: AI can be used to create different pictures for everyone. You only need to tell everyone the general requirements. 3. AI chat: can create an AI that can chat for users,

Both vivox100s and x100 mobile phones are representative models in vivo's mobile phone product line. They respectively represent vivo's high-end technology level in different time periods. Therefore, the two mobile phones have certain differences in design, performance and functions. This article will conduct a detailed comparison between these two mobile phones in terms of performance comparison and function analysis to help consumers better choose the mobile phone that suits them. First, let’s look at the performance comparison between vivox100s and x100. vivox100s is equipped with the latest

With the rapid development of the Internet, the concept of self-media has become deeply rooted in people's hearts. So, what exactly is self-media? What are its main features and functions? Next, we will explore these issues one by one. 1. What exactly is self-media? We-media, as the name suggests, means you are the media. It refers to an information carrier through which individuals or teams can independently create, edit, publish and disseminate content through the Internet platform. Different from traditional media, such as newspapers, television, radio, etc., self-media is more interactive and personalized, allowing everyone to become a producer and disseminator of information. 2. What are the main features and functions of self-media? 1. Low threshold: The rise of self-media has lowered the threshold for entering the media industry. Cumbersome equipment and professional teams are no longer needed.

If you need to program any device remotely, this article will help you. We will share the top GE universal remote codes for programming any device. What is a GE remote control? GEUniversalRemote is a remote control that can be used to control multiple devices such as smart TVs, LG, Vizio, Sony, Blu-ray, DVD, DVR, Roku, AppleTV, streaming media players and more. GEUniversal remote controls come in various models with different features and functions. GEUniversalRemote can control up to four devices. Top Universal Remote Codes to Program on Any Device GE remotes come with a set of codes that allow them to work with different devices. you may

As a programmer, I get excited about tools that simplify the coding experience. With the help of artificial intelligence tools, we can generate demo code and make necessary modifications as per the requirement. The newly introduced Copilot tool in Visual Studio Code allows us to create AI-generated code with natural language chat interactions. By explaining functionality, we can better understand the meaning of existing code. How to use Copilot to generate code? To get started, we first need to get the latest PowerPlatformTools extension. To achieve this, you need to go to the extension page, search for "PowerPlatformTool" and click the Install button

As Xiaohongshu becomes popular among young people, more and more people are beginning to use this platform to share various aspects of their experiences and life insights. How to effectively manage multiple Xiaohongshu accounts has become a key issue. In this article, we will discuss some of the features of Xiaohongshu account management software and explore how to better manage your Xiaohongshu account. As social media grows, many people find themselves needing to manage multiple social accounts. This is also a challenge for Xiaohongshu users. Some Xiaohongshu account management software can help users manage multiple accounts more easily, including automatic content publishing, scheduled publishing, data analysis and other functions. Through these tools, users can manage their accounts more efficiently and increase their account exposure and attention. In addition, Xiaohongshu account management software has

PHP Tips: Quickly implement the function of returning to the previous page. In web development, we often encounter the need to implement the function of returning to the previous page. Such operations can improve the user experience and make it easier for users to navigate between web pages. In PHP, we can achieve this function through some simple code. This article will introduce how to quickly implement the function of returning to the previous page and provide specific PHP code examples. In PHP, we can use $_SERVER['HTTP_REFERER'] to get the URL of the previous page

"Exploring Discuz: Definition, Functions and Code Examples" With the rapid development of the Internet, community forums have become an important platform for people to obtain information and exchange opinions. Among the many community forum systems, Discuz, as a well-known open source forum software in China, is favored by the majority of website developers and administrators. So, what is Discuz? What functions does it have, and how can it help our website? This article will introduce Discuz in detail and attach specific code examples to help readers learn more about it.
