JavaScript implements copy function
Ignore the compatibility of the browser and look at the support of each browser for the copy function:
1. IE browser, there are three solutions, the code is as follows:
[javascript]
function copy(txtid) {
var txtObj = document.getElementById(txtid);
if(window.clipboardData){ // Only IE supports this object, firefox and chrome do not support it
// 1. Copy through the clipboardData object
// window.clipboardData.clearData();
B //txtObj.Select ();
//document.execcommand 18); // Only IE supports, firefox reports grammatical errors, chrome execution results return false (not support)
// 3 The current copy is implemented through the textRange object: you don't need to select the content first
txtObj.createtextRange (). Execocommand ("Copy"); .getElementById(txtid);
if(window.clipboardData){ // Only IE supports this object, firefox and chrome do not support it
//1. Copy through clipboardData object
//window.clipboardData.clearData() ;
//window.clipboardData.setData("Text",txtObj.value);
//2. Copy through the document object: first select the Chinese text, and then execute the copy command
//txtObj.select ();
//document.execCommand("Copy"); // Only supported by IE, Firefox reports a syntax error, and the chrome execution result returns false (not supported)
//3. Realize current copy through TextRange object : You don’t need to select the content first
txtObj.createTextRange().execCommand("Copy");
}
}
2. Firefox, implemented through the interface method, Firefox is for security reasons, in 17 Later versions will close this interface, and it will be available in versions 17 and earlier. The code is as follows:
[javascript]
var clip = Components.classes['@mozilla.org/widget/clipboard;1'].createInstance(Components.interface.nsIClipboard);
var clip = Components.classes ['@mozilla.org/widget/clipboard;1'].createInstance(Components.interface.nsIClipboard); 3. Chrome does not provide users with clipboard operations due to security reasons. It can be seen that the support for the copy function is not uniform across browsers.
Zero Clipboard Library
Zero Clipboard js library written by jhuckaby, which uses Flash to copy content to the clipboard. As long as the browser is equipped with the Flash plug-in, the content can be copied. ActionScript is used to shield the shortcomings of JavaScript and solve the problem of copy compatibility between browsers.
The implementation principle of Zero Clipboard: Zero Clipboard first generates a Flash object label, allowing the transparent Flash to float on the copy button. In fact, what is clicked is not the button but the Flash. In this way, the required content is transferred to Flash, and then Copy to system clipboard via Flash.
How to use Zero Clipboard
Note: Because it is based on Flash implementation, Flash needs to be run in a Web container (such as Apache, Tomcat) for security reasons. Opening Flash directly will not be loaded. , the button is similar to the phenomenon of suspended animation. It is said on the Internet that right-clicking Flash settings will add ZeroClipboard.swf to a trusted location. It seems that it should work. I tried it, but it still doesn't work. It may also be a problem with my local browser.
1> Download the compressed package of Zero Clipboard, unzip it and put the two files in the folder: ZeroClipboard.js and ZeroClipboard.swf into your project;
2> Introduce the Zero Clipboard.js file , the following code: ;
Note: ZeroClipboard.js and ZeroClipboard.swf need to be placed in the same path. If If they are not in the same path, you can use ZeroClipboard.setMoviePath() to set it.
3>Simple copy the code as follows:
[javascript]
var clip = new ZeroClipboard.Client(); // Create a new clip object
clip.setHandCursor( true ); // Settings The mouse is a hand type
clip.setText("hello,world"); use using using ’ ’ s ’ s ’ s ’ ‐ ‐ ‐ ‐ ‐ Button, the parameter is the id of the button element, you can copy it by clicking the button
var clip = new ZeroClipboard.Client(); //Create a new clip object
clip.setHandCursor(true); The copied text can be the value of the text box
clip.glue("copy-botton"); // Register a button for clip, the parameter is the id of the button element, click the button to copy
4>Zero Clipboard Commonly used methods, it is recommended to view the source code directly:
reposition(): to prevent the Flash button from being misaligned when the page size changes
hide(): hide the Flash button
show(): display Flash button
setCSSEffects(): Solve the problem of Flash occlusion button style failure (change :hover to .hover).
5>Zero Clipboard common events, the event handler function is addEventListener():
load: Flash button loading event
mouseOver: mouse move up event
mouseOut: mouse move out event
mouseDown : mouse Press event
mouseUp: mouse release event
complete: copy success event
jquery.zclip library
Since ZeroClipboard is based on native JavaScript, jquery.zclip uses jQuery to implement Zero Clip board For encapsulation, if jQuery is already used in the project, it is recommended to use it, jquery.zclip is smaller in size.

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

AI Hentai Generator
Generate AI Hentai for free.

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

Detailed explanation of JavaScript string replacement method and FAQ This article will explore two ways to replace string characters in JavaScript: internal JavaScript code and internal HTML for web pages. Replace string inside JavaScript code The most direct way is to use the replace() method: str = str.replace("find","replace"); This method replaces only the first match. To replace all matches, use a regular expression and add the global flag g: str = str.replace(/fi

Leverage jQuery for Effortless Web Page Layouts: 8 Essential Plugins jQuery simplifies web page layout significantly. This article highlights eight powerful jQuery plugins that streamline the process, particularly useful for manual website creation

So here you are, ready to learn all about this thing called AJAX. But, what exactly is it? The term AJAX refers to a loose grouping of technologies that are used to create dynamic, interactive web content. The term AJAX, originally coined by Jesse J

This post compiles helpful cheat sheets, reference guides, quick recipes, and code snippets for Android, Blackberry, and iPhone app development. No developer should be without them! Touch Gesture Reference Guide (PDF) A valuable resource for desig

jQuery is a great JavaScript framework. However, as with any library, sometimes it’s necessary to get under the hood to discover what’s going on. Perhaps it’s because you’re tracing a bug or are just curious about how jQuery achieves a particular UI

10 fun jQuery game plugins to make your website more attractive and enhance user stickiness! While Flash is still the best software for developing casual web games, jQuery can also create surprising effects, and while not comparable to pure action Flash games, in some cases you can also have unexpected fun in your browser. jQuery tic toe game The "Hello world" of game programming now has a jQuery version. Source code jQuery Crazy Word Composition Game This is a fill-in-the-blank game, and it can produce some weird results due to not knowing the context of the word. Source code jQuery mine sweeping game

Article discusses creating, publishing, and maintaining JavaScript libraries, focusing on planning, development, testing, documentation, and promotion strategies.

This tutorial demonstrates how to create a captivating parallax background effect using jQuery. We'll build a header banner with layered images that create a stunning visual depth. The updated plugin works with jQuery 1.6.4 and later. Download the
