一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

復(fù)制Input內(nèi)容的js代碼_支持所有瀏覽器,修正了Firefox3.5以上的問題


但IE6兩行JS代碼就可以,IE7以上也差不多,只不過出來一個安全提示比較惡心,用戶如果看到了,一定有懷疑;
再但就是Firefox、Chrome等根本就不讓你復(fù)制;
記得以前網(wǎng)上有這方面的代碼,找了一下,發(fā)現(xiàn)全部不能在firefox3.5以上的版本中應(yīng)該,最后終于找到了一個,代碼還相當(dāng)相當(dāng)?shù)膹?fù)雜,不太敢用。
最后,憋的實在沒有辦法了,查了查資料,自已寫了一個:
主要的理解的幾個點:
1、Firefox這些瀏覽器,出于安全考慮吧,直接是不讓復(fù)制的;
2、在Flash中,可以用System.setClipboard(),把內(nèi)容扔到剪貼板上,然后再讓FLASH工作在Firefox下;
3、在Flash播放器10.0之后呢,也是出于安全考慮吧,System.setClipboard的內(nèi)容必須在FLASH里邊;
4、用ExternalInterface可以和JS通信;
5、ExternalInterface在flash8中必須引用一下才可以;
默認的HTML代碼:
復(fù)制代碼 代碼如下:
<input type="text" id="testInput" name="testInput" value="4234324234" />
<div id="buttonBox">
<button onclick="copy('testInput')">copy</button>
</div>

所以,設(shè)計的時候,先作第一個判斷,如果是IE,就還用默認的代碼,這樣最沒有問題,如果不是,就用一個FLASH把默認的按鈕覆蓋;
復(fù)制代碼 代碼如下:
if (window.XMLHttpRequest){//如果不是IE時,就用FLASH的方式復(fù)制
$('buttonBox').innerHTML = '<embed src="flashCopy.swf" width="48"
height="23" quality="high"
pluginspage="http://www.macromedia.com/go/getflashplayer"
type="application/x-shockwave-flash"></embed>';
}

以下是所有的JS文件:
復(fù)制代碼 代碼如下:
<script>
function $(id){
return document.getElementById(id);
}
function copy(){//ie6
var value = $('testInput').value;
window.clipboardData.clearData();
window.clipboardData.setData("Text", value);
alert('復(fù)制成功!');
}
function flashCopy(){//firefox .......
return $('testInput').value;
}
function flashCopyBack(){
alert('復(fù)制成功!');
}
if("v" != "v"){//如果不是IE時,就用FLASH的方式復(fù)制
$('buttonBox').innerHTML = '<embed src="111.swf" width="48" height="23" quality="high" pluginspage="http://www.macromedia.com/go/getflashplayer" type="application/x-shockwave-flash"></embed>';
}
</script>

FLASH按鈕的代碼如下:
復(fù)制代碼 代碼如下:
on (release) {
import flash.external.ExternalInterface;
var inputText = ExternalInterface.call('flashCopy');
System.setClipboard(inputText);
ExternalInterface.call('flashCopyBack');
//_root.boboText.text = inputText;
}

原理,就是避開那個安全上的限制,在點FLASH中的按鈕時,通過FLASH中的代碼去調(diào)頁面中的JS代碼,JS代碼可以拿到INPUT中的值,然后再傳給FLASH,這時,F(xiàn)LASH中就有了這些值了,然后,F(xiàn)LASH自已再通過System.setClipboard把這些值存到剪貼板上; 再然后,他再去調(diào)用頁面中的flashCopyBack,flashCopyBack只干一件事,就是提示已復(fù)制成功!
我在Firefox、chrome、ie中都測過了,沒有問題,如果誰發(fā)現(xiàn)有問題,請告訴我,謝謝,因為我現(xiàn)在已經(jīng)開始用!
轉(zhuǎn)載請注明出處:子鼠

JavaScript技術(shù)復(fù)制Input內(nèi)容的js代碼_支持所有瀏覽器,修正了Firefox3.5以上的問題,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲一区二区三区免费视频 | 国产精品视频国产永久视频 | 亚洲综合第一页 | 久久性妇女精品免费 | 欧美一级久久 | 一区二区三区在线免费看 | 亚洲三级色 | 皇色在线视频 | 四虎永久在线观看免费网站网址 | 亚洲伊人久久大香线蕉结合 | 免费看一级做a爰片久久 | 亚洲一区二区三区四 | 日韩欧美精品一区二区三区 | 四虎影视永久免费观看网址 | 精品久久久久久久一区二区手机版 | 国产一区二区三区在线 | 亚洲国产成人在线 | 成人亚洲视频在线观看 | 99精品视频在线成人精彩视频 | 国产成人青草视频 | 国内久久久久久久久久 | www日本视频 | 一色网| 男人女人无遮掩免费视频 | 欧美激情在线观看 | 91原创视频在线观看 | 国产精品美女久久久久网站 | 精品视频免费观看 | 精品日韩在线视频一区二区三区 | 91人人看 | 中文字幕在线观看一区二区 | 美女张腿男人桶免费视频 | 97精品国产91久久久久久久 | 2020国产精品 | 成人婷婷 | 99精品大香线蕉线伊人久久久 | 激情综合丝袜美女一区二区 | 免费一区二区三区在线视频 | 亚洲国产97在线精品一区 | 91极品视频 | 激情五月婷婷小说 |