Ⅰ jquery或js復制/ 粘貼事件
如果你只是想復實現復制制id為txt的div中的文本的話:
$("#cpy").click(function(){//注冊復制的點擊事件
alert('復製成功!');//因為根本就不用復制功能只是一個從txt_div中取值的過程
});
$("#past").click(function(){
$("textarea").val($("#txt").text());
alert('粘貼成功!');
});
現代瀏覽器基於安全考慮,js 是無法直接讀取剪貼板的。
唯一的可能性是,用戶在可編輯元素中(如contenteditable='true'
的 div)主動觸發粘貼操作(如,通過 ctrl+V)。此時通過監聽 paste 事件, 可以從event中獲取到用戶所粘貼的內容。
示例代碼(支持現代瀏覽器):
<divid='editableDiv'contenteditable='true'>Pastehere</div>
functionhandlePaste(e){
varclipboardData,pastedData;
//阻止粘貼
e.stopPropagation();
e.preventDefault();
//獲取剪貼板信息
clipboardData=e.clipboardData||window.clipboardData;
//獲取剪貼板內容,getData的參數是數據類型,這里為了獲取文件路徑是'URL';如果想獲取粘貼的文本,用'Text'
pastedData=clipboardData.getData('URL');
//處理信息,此時pastedData應該是'file:///path/to/xxx'
alert(pastedData);
}
document.getElementById('editableDiv').addEventListener('paste',handlePaste);
但是,與其費心思這樣做,為何不直接做成拖動上傳呢,應該更易於使用吧。
示例來源
http://stackoverflow.com/questions/2176861/javascript-get-clipboard-data-on-paste-event-cross-browser/2177059#2177059
Ⅲ JavaScript如何點擊實現復制文字到剪切板
可以使用clipboard插件解決這個問題。
github里直接搜索clipboard就可以找到了。
這里答的.btn是元素的class屬性,可以使用任意id或者class以及元素節點名稱來實例化插件。
默認會為元素綁定click事件,點擊的時候會觸發。
data-clipboard-target參數指定被復制內容的元素。
如上例,點擊按鈕後會將input的值「被復制的內容」幾個字復制到剪切板中。
更多使用方法可以自行github查詢。
Ⅳ 如何利用JS實現復制/粘貼功能
1、最基本的復制
代碼
<script language="JavaScript">
function readTxt()
{
alert(window.clipboardData.getData("text"));
}
function setTxt()
{
var t=document.getElementById("txt");
t.select();
window.clipboardData.setData('text',t.createTextRange().text);
}
</script>
<input name="txt" value="測試">
<input type="button" value="復制" onclick="setTxt()">
<input type="button" value="讀取" onclick="readTxt()">
2、擴展復制:復製表格
Java代碼
<INPUT TYPE="button" value="選中測試表格" onclick="CopyTable()">
測試
<TABLE border="1" id="oTable">
<TR>
<TD>測試表格</TD>
<TD>測試表格</TD>
</TR>
<TR>
<TD>測試表格</TD>
<TD>測試表格</TD>
</TR>
</TABLE>文字
<SCRIPT LANGUAGE="JavaScript">
<!--
function CopyTable()
{
var txt = document.body.createTextRange();
txt.moveToElementText(document.getElementById('oTable'));
txt.select();
}
//-->
</SCRIPT>
、兼容IE,firefox等瀏覽器的復制
Java代碼
<script>
function ToClipboard(txt) {
if(window.clipboardData) {
window.clipboardData.clearData();
window.clipboardData.setData("Text", txt);
} else if(navigator.userAgent.indexOf("Opera") != -1) {
window.location = txt;
} else if (window.netscape) {
try {
netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
} catch (e) {
alert("被瀏覽器拒絕!\n請在瀏覽器地址欄輸入'about:config'並回車\n然後將'signed.applets.codebase_principal_support'設置為'true'");
}
var clip = Components.classes['@mozilla.org/widget/clipboard;1'].createInstance(Components.interfaces.nsIClipboard);
if (!clip)
return;
var trans = Components.classes['@mozilla.org/widget/transferable;1'].createInstance(Components.interfaces.nsITransferable);
if (!trans)
return;
trans.addDataFlavor('text/unicode');
var str = new Object();
var len = new Object();
var str = Components.classes["@mozilla.org/supports-string;1"].createInstance(Components.interfaces.nsISupportsString);
var text = txt;
str.data = text;
trans.setTransferData("text/unicode",str,text.length*2);
var clipid = Components.interfaces.nsIClipboard;
if (!clip)
return false;
clip.setData(trans,null,clipid.kGlobalClipboard);
}
}
</script>
<button onclick="ToClipboard('你好!');">復制文本「你好!」</button>
<textarea id="test"></textarea>
Ⅳ JavaScript中的事件都有哪些阿
onabort 當用戶中斷下載圖像時觸發。
onactivate 當對象設置為活動元素時觸發。
onafterprint 對象所關聯的文檔列印或列印預覽後立即在對象上觸發。
onafterupdate 當成功更新數據源對象中的關聯對象後在數據綁定對象上觸發。
onbeforeactivate new 對象要被設置為當前元素前立即觸發。
onbefore 當選中區復制到系統剪貼板之前在源對象觸發。
onbeforecut 當選中區從文檔中刪除之前在源對象觸發。
onbeforedeactivate 在 activeElement 從當前對象變為父文檔其它對象之前立即觸發。
onbeforeeditfocus 在包含於可編輯元素內的對象進入用戶界面激活狀態前或可編輯容器變成控制項選中區前觸發。
onbeforepaste 在選中區從系統剪貼板粘貼到文檔前在目標對象上觸發。
onbeforeprint 對象的關聯文檔列印或列印預覽前在對象上觸發。
onbeforeunload 在頁面將要被卸載前觸發。
onbeforeupdate 當成功更新數據源對象中的關聯對象前在數據綁定對象上觸發。
onblur 在對象失去輸入焦點時觸發。
onbounce 當 marquee 對象的 behavior 屬性設置為「alternate」且字幕的內容到達窗口一邊時觸發。
oncellchange 在數據供應者中的數據變更時觸發。
onchange 當對象或選中區的內容改變時觸發。
onclick 在用戶用滑鼠左鍵單擊對象時觸發。
oncontextmenu 在用戶使用滑鼠右鍵單擊客戶區打開上下文菜單時觸發。
oncontrolselect 當用戶將要對該對象製作一個控制項選中區時觸發。
on 當用戶復制對象或選中區,將其添加到系統剪貼板上時在源元素上觸發。
oncut 當對象或選中區從文檔中刪除並添加到系統剪貼板上時在源元素上觸發。
ondataavailable 每當非同步傳輸數據的數據源對象的數據到達時觸發。
ondatasetchanged 當數據源對象對應的數據集發生變更時觸發。
ondatasetcomplete 觸發就表明數據源對象所有數據都可用。
ondblclick 當用戶雙擊對象時觸發。
ondeactivate 當 activeElement 從當前對象變為父文檔其它對象時觸發。
ondrag 當進行拖曳操作時在源對象上持續觸發。
ondragend 當用戶在拖曳操作結束後釋放滑鼠時在源對象上觸發。
ondragenter 當用戶拖曳對象到一個合法拖曳目標時在目標元素上觸發。
ondragleave 當用戶在拖曳操作過程中將滑鼠移出合法拖曳目標時在目標對象上觸發。
ondragover 當用戶拖曳對象劃過合法拖曳目標時持續在目標元素上觸發。
ondragstart 當用戶開始拖曳文本選中區或選中對象時在源對象上觸發。
ondrop 當滑鼠按鈕在拖曳操作過程中釋放時在目標對象上觸發。
onerror 當對象裝載過程中發生錯誤時觸發。
onerrorupdate 更新數據源對象中的關聯數據出錯時在數據綁定對象上觸發。
onfilterchange 當可視濾鏡更改狀態或完成轉換時觸發。
onfinish 當字幕循環完成後觸發。
onfocus 當對象獲得焦點時觸發。
onfocusin new 當元素將要被設置為焦點之前觸發。
onfocusout new 在移動焦點到其它元素之後立即觸發於當前擁有焦點的元素上觸發。
onhelp 當用戶在瀏覽器為當前窗口時按 F1 鍵時觸發。
onkeydown 當用戶按下鍵盤按鍵時觸發。
onkeypress 當用戶按下字面鍵時觸發。
onkeyup 當用戶釋放鍵盤按鍵時觸發。
onlayoutcomplete 當列印或列印預覽版面處理完成用來自於源文檔的內容填充當前 LayoutRect 對象時觸發。
onload 在瀏覽器完成對象的裝載後立即觸發。
onlosecapture 當對象失去滑鼠捕捉時觸發。
onmousedown 當用戶用任何滑鼠按鈕單擊對象時觸發。
onmouseenter 當用戶將滑鼠指針移動到對象內時觸發。
onmouseleave 當用戶將滑鼠指針移出對象邊界時觸發。
onmousemove 當用戶將滑鼠劃過對象時觸發。
onmouseout 當用戶將滑鼠指針移出對象邊界時觸發。
onmouseover 當用戶將滑鼠指針移動到對象內時觸發。
onmouseup 當用戶在滑鼠位於對象之上時釋放滑鼠按鈕時觸發。
onmousewheel new 當滑鼠滾輪按鈕旋轉時觸發。
onmove 當對象移動時觸發。
onmoveend 當對象停止移動時觸發。
onmovestart 當對象開始移動時觸發。
onpaste 當用戶粘貼數據以便從系統剪貼板向文檔傳送數據時在目標對象上觸發。
onpropertychange 當在對象上發生對象上發生屬性更改時觸發。
onreadystatechange 當對象狀態變更時觸發。
onreset 當用戶重置表單時觸發。
onresize 當對象的大小將要改變時觸發。
onresizeend 當用戶更改完控制項選中區中對象的尺寸時觸發。
onresizestart 當用戶開始更改控制項選中區中對象的尺寸時觸發。
onrowenter 觸發就表明當前行已經在數據源中更改,對象上有可用的新數據值。
onrowexit 當數據源控制項更改對象當前行前觸發。
onrowsdelete 當行將要從記錄集中被刪除時觸發。
onrowsinserted 當在當前記錄集中插入新行後觸發。
onscroll 當用戶滾動對象的滾動條時觸發。
onselect 當當前選中區改變時觸發。
onselectionchange 當文檔的選中狀態改變時觸發。
onselectstart 對象將要被選中時觸發。
onstart 在 marquee 對象的每次循環開始時觸發。
onstop 當用戶單擊停止按鈕或離開 Web 頁面時觸發。
onsubmit 當表單將要被提交時觸發。