Home Web Front-end JS Tutorial JavaScript implements copy function

JavaScript implements copy function

Nov 28, 2016 am 11:32 AM
JavaScript

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.

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Replace String Characters in JavaScript Replace String Characters in JavaScript Mar 11, 2025 am 12:07 AM

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

8 Stunning jQuery Page Layout Plugins 8 Stunning jQuery Page Layout Plugins Mar 06, 2025 am 12:48 AM

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

Build Your Own AJAX Web Applications Build Your Own AJAX Web Applications Mar 09, 2025 am 12:11 AM

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

10 Mobile Cheat Sheets for Mobile Development 10 Mobile Cheat Sheets for Mobile Development Mar 05, 2025 am 12:43 AM

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

Improve Your jQuery Knowledge with the Source Viewer Improve Your jQuery Knowledge with the Source Viewer Mar 05, 2025 am 12:54 AM

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 jQuery Fun and Games Plugins 10 jQuery Fun and Games Plugins Mar 08, 2025 am 12:42 AM

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

How do I create and publish my own JavaScript libraries? How do I create and publish my own JavaScript libraries? Mar 18, 2025 pm 03:12 PM

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

jQuery Parallax Tutorial - Animated Header Background jQuery Parallax Tutorial - Animated Header Background Mar 08, 2025 am 12:39 AM

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

See all articles