DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript基礎知識 >> javaScript復制功能調用實現方案
javaScript復制功能調用實現方案
編輯:JavaScript基礎知識     
復制代碼 代碼如下:
驗證碼:<input type="text" id="code"/> <input type="button" value="復制" onclick="fuzhi()">
<script type="text/javascript">
function fuzhi(){
var codeVal=jQuery("#code").val();
alert(codeVal);
if (navigator.userAgent.toLowerCase().indexOf('ie') > -1) { //IE浏覽器
clipboardData.setData('Text', codeVal);
alert("已經復制到剪切板");
} else {
prompt("請復制:", codeVal);
}
// window.clipboardData.setData("Text",jQuery("#code").val());
}
</script>


最近都沒有什心情去寫博文,主要因為心煩的事情漸漸多起來了。
哎!離題了,回到這篇文章了。說到使用js實現點擊復制的功能,我下面想說的方法也是和網上的大同小異的。js實現是很簡單,最難的是兼容問題,畢竟用IE以外的人還是有很多的。這裡,我也是根據網上的相關資源總結一下方法。

方法一,逐一判別處理法
方法很簡單也很容易懂,就是通過判斷客戶端浏覽器類別,來執行不同的js代碼來實現復制功能。雖然從理論上來說,這樣是行得通得。但是,事實並沒有我們想得那麼容易。因為我們並不太清楚一些浏覽器下js復制代碼的寫法,至少我所知道的也就是IE和FF。

如果只是兼容IE和FF的話,那麼簡單得多了。這裡我使用一個網上比較有名的判斷IE核的方法,13字節法,這個也是我常用的。
復制代碼 代碼如下:
if("\v"=="v") {//13個字節
//這裡是IE核,執行的代碼,親測兼容IE8
}else{
//非IE核執行代碼
}

這裡我寫個大概的實現復制的構架,具體代碼我不粘上來的,網上可以很簡單就找到,給大家參考
復制代碼 代碼如下:
function clipBoard(object){
//獲取object的值,即復制內容
var copyTxt=document.getElementById(object).value;
//調用copy2Clipboar來實現浏覽器,判斷及執行代碼
if(copy2Clipboard(copyTxt)!= false){
alert('復制成功');
}
}
copy2Clipboard = function(txt){
if("\v"=="v"){
//IE浏覽器執行代碼
window.clipboardData.clearData();
window.clipboardData.setData("Text",txt);
return true;
}else if(navigator.userAgent.indexOf("Firefox")>0){
//Firefox浏覽器
return true;
}else if(window.google && window.chrome){
//chrome浏覽器
return true;
}else{
alert("浏覽器不支持");
return false;
}
}

根據需要可以自行添加不同的判斷浏覽器代碼,實現該浏覽器下的復制功能。一般情況下,根據IE > FF > opera/chrome>其他,這樣的順序進行判斷。

方法二,flash間接處理法
原理很簡單,通過創建一個flash,將復制的內容以變量的方式傳遞給flash,flash再將內容復制到內存中,這樣就實現了復制的功能。只要支持flash,按理上是可以兼容絕大部分的浏覽器的,這個方法是我今天看到的,也測試驗證了。

安裝及使用方法,可以在上面兩個網址上找到,E文版,中文版只有通過搜索去找咯!
這裡我提供一下實現框架的簡單版,這裡有用到上面的實現方式。這裡有修改的,根據官方版說明方法,在單頁面很容易就能實現該功能,但是在實際應用到某些CMS中,可能會遇到一些問題。什麼問題呢?IE核頁面會彈出 “該頁面已終止”。原因很簡單,就是js加載未完成就調用。竟然是IE的問題,那麼我們就可以使用判斷IE的方法,將IE獨立出來,其他核就使用flash方法實現。
復制代碼 代碼如下:
function checkClient(object){//判斷浏覽器
var copyTxt=document.getElementById(object).value; //獲取復制的內容
if("v"!="v"){
//這裡根據官方文檔設置
//這裡設置flash位置,絕對相對都可以
ZeroClipboard.setMoviePath('ZeroClipboard.swf');
//創建一個復制對象
var clip = new ZeroClipboard.Client();
//設置手形
clip.setHandCursor(true);
//設置復制的內容
clip.setText(copyTxt);
//設置觸發對象
>clip.glue('d_clip_button');
}
}

這裡用於判斷是否為IE核,IE核將不使用flash處理法,直接使用復制機制
復制代碼 代碼如下:
//復制處理
function clipBoard(object){
var copyTxt=document.getElementById(object).value;
if(copy2Clipboard(copyTxt)!= false){
alert('復制成功');
}
}
copy2Clipboard = function(txt){
if("\v"=="v") { //判斷是否是IE浏覽器
window.clipboardData.clearData();
window.clipboardData.setData("Text",txt);
return true;
}
else{ //非IE核直接返回
return true;
}

以上為第二種方法的最簡單設置方法,將代碼放到<head></head>之間即可不管是第一種,還是第二種方法都要在需要復制的頁面上添加下面兩行代碼
設置復制內容的文本域
復制代碼 代碼如下:
<input type="text" id="textinfo"
onmouseout="checkClient('textinfo')" value="復制的內容" size="65"/>

設置觸發對象按鈕
復制代碼 代碼如下:
<div id="d_clip_button" onclick="copyCode('textinfo')">復制地址</div>

這是第二種方法才要添加的,設置檢測浏覽器
復制代碼 代碼如下:
<script>checkClient('textinfo');</script>

寫到這裡,大概的步驟就是這樣了,其中還有些id的名稱可以按需要修改。至少完整代碼,可以參考官方的demo。
累了。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved