Javascript Copy Text To Clipboard

Issues arise when you want to copy text to the clipboard using javascript. Firefox provides a security measure which prevents you from doing it so a workaround has to be made for it to happen. I am using IE7 for my IE testing and in this version, it also has a security feature although less strict than Firefox. Whenever you browse to a new page that has a copy to clipboard function, a popup window prompts you asking if you want to allow the webpage to access your clipboard. Normally, you would choose no. But instances may require you to like if the site you are accessing is yours or related to your needs and you have the utmost trust that the script won’t harm your PC or something. Anyway, to provide copy to clipboard functionality using Javascript, I found this function in this site does the job by using a little .SWF file. You can download the file there or if you want to use Google App Engine, the code function below will do. It also works in Safari, IE, and Opera.

function copyToClipboard(text) {
	var flashId = 'flashId-HKxmj5';
 
	/* Replace this with your clipboard.swf location */
	var clipboardSWF = 'http://appengine.bravo9.com/copy-into-clipboard/clipboard.swf';
 
	if (!document.getElementById(flashId)) {
		var div = document.createElement('div');
		div.id = flashId;
		document.body.appendChild(div);
	}
 
	document.getElementById(flashId).innerHTML = '';
	var content = '<embed src="' +
	clipboardSWF +
	'" FlashVars="clipboard=' + encodeURIComponent(text) +
	'" width="0" height="0" type="application/x-shockwave-flash"></embed>';
 
	document.getElementById(flashId).innerHTML = content;
}
No TweetBacks yet. (Be the first to Tweet this post)

Like what you see? Buy me a cup of coffee. Or subscribe to my feeds.


(No Ratings Yet)
 Loading ...

12 Responses to “Javascript Copy Text To Clipboard”

Pages: « 1 2 [3] Show All

  1. 11
    tech Says:

    this is odd, because in firefox 2 and 3, this works. i checked it again. perhaps you installed a flash swf blocker plugin? because that won’t work unless you start the flash plugin used to copy the text to clipboard.

    i also checked this out in safari 3.1 (525.13). would be weird if a new version can’t support old ones.

    IE6 works fine. i checked it again :)

  2. 12
    Bill Beckelman Says:

    This method is not working if you install Flash 10 due to some security changes.

    http://www.adobe.com/devnet/flashplayer/articles/fplayer10_security_changes_02.html#head31

    Looking for a workaround :)

Pages: « 1 2 [3] Show All

Leave a Reply