javascript在網(wǎng)頁中實現(xiàn)讀取剪貼板粘貼截圖功能
見某網(wǎng)站的輸入框支持截屏粘貼的功能,覺得有點意思,于是將代碼扒出來分享下。
可惜,目前僅有高版本的 Chrome 瀏覽器支持這樣直接粘貼,其他瀏覽器目前為止還無法粘貼( IE11沒測試過 ),當(dāng)然這種增強型的用戶體驗功能有總比沒有好。
輸入框的結(jié)構(gòu)代碼:
<input type="text" id="testInput" />
為輸入框綁定粘貼事件:
var input = document.getElementById( 'testInput' );
input.addEventListener( 'paste', function( event ){
// dosomething...
});
粘貼事件的 Event 接口對象提供了一個 clipboardData 接口,該接口就保存了系統(tǒng)剪貼板中的數(shù)據(jù),如上面所說,目前只有高版本的 Chrome 瀏覽器能直接訪問系統(tǒng)剪貼板的數(shù)據(jù)。這就給截屏后保存到剪貼板中的圖片于網(wǎng)頁直接進行交互提供了一個入口。
這里所說的截屏,就是 QQ 提供的截屏或者系統(tǒng)自帶的 PrtScn 鍵的截屏功能,或者其他第三方軟件提供的截屏功能。
input.addEventListener( 'paste', function( event ){
// 添加到事件對象中的訪問系統(tǒng)剪貼板的接口
var clipboardData = event.clipboardData,
i = 0,
items, item, types;
if( clipboardData ){
items = clipboardData.items;
if( !items ){
return;
}
item = items[0];
// 保存在剪貼板中的數(shù)據(jù)類型
types = clipboardData.types || [];
for( ; i < types.length; i++ ){
if( types[i] === 'Files' ){
item = items[i];
break;
}
}
// 判斷是否為圖片數(shù)據(jù)
if( item && item.kind === 'file' && item.type.match(/^image\//i) ){
// 讀取該圖片
imgReader( item );
}
}
});
從剪貼板中取到了圖片數(shù)據(jù),就可以用 FileReader 對其進行讀取了。
var imgReader = function( item ){
var file = item.getAsFile(),
reader = new FileReader();
// 讀取文件后將其顯示在網(wǎng)頁中
reader.onload = function( e ){
var img = new Image();
img.src = e.target.result;
document.body.appendChild( img );
};
// 讀取文件
reader.readAsDataURL( file );
};
很短的代碼就實現(xiàn)了,可以使用以下源碼看看演示。
<!DOCTYPE HTML>
<html lang="en-US">
<head>
<meta charset="UTF-8">
<title>利用 clipboardData 在網(wǎng)頁中實現(xiàn)截屏粘貼的功能</title>
<style type="text/css">
#box{ width:200px; height:200px; border:1px solid #ddd; }
</style>
</head>
<body>
<h1>利用 clipboardData 在網(wǎng)頁中實現(xiàn)截屏粘貼的功能</h1>
<hr />
<div><input type="text" id="testInput" placeholder="截屏后粘貼到輸入框中" size="30" /></div>
<script type="text/javascript">
(function(){
var imgReader = function( item ){
var blob = item.getAsFile(),
reader = new FileReader();
reader.onload = function( e ){
var img = new Image();
img.src = e.target.result;
document.body.appendChild( img );
};
reader.readAsDataURL( blob );
};
document.getElementById( 'testInput' ).addEventListener( 'paste', function( e ){
var clipboardData = e.clipboardData,
i = 0,
items, item, types;
if( clipboardData ){
items = clipboardData.items;
if( !items ){
return;
}
item = items[0];
types = clipboardData.types || [];
for( ; i < types.length; i++ ){
if( types[i] === 'Files' ){
item = items[i];
break;
}
}
if( item && item.kind === 'file' && item.type.match(/^image\//i) ){
imgReader( item );
}
}
});
})();
</script>
</body>
</html>
相關(guān)文章
JavaScript刪除有序數(shù)組中的重復(fù)項
這篇文章主要介紹了JavaScript刪除有序數(shù)組中的重復(fù)項,主要解決有序數(shù)組?nums?,要求原地刪除重復(fù)出現(xiàn)的元素,使每個元素只出現(xiàn)一次,返回刪除后數(shù)組的新長的問題,下面實現(xiàn)操作,需要的小伙伴可以參考一下2022-03-03javascript中的undefined 與 null 的區(qū)別 補充篇
在Javascript中有兩個值用來代表類似空值的概念,undefined和null,這兩個很容易被混淆,他們表示的是兩個不同的概念。2010-03-03electron-builder書寫nsis腳本在安裝electron程序時安裝其他應(yīng)用程序(完美解決方案)
這篇文章主要介紹了electron-builder書寫nsis腳本在安裝electron程序時安裝其他應(yīng)用程序的解決方案,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-03-03css transform 3D幻燈片特效實現(xiàn)步驟解讀
3D幻燈片特效想必大家以不在陌生至于表現(xiàn)形式一般都是拘泥于傳統(tǒng)接下來為大家介紹下使用css3 transform配合js以及html實現(xiàn)3D幻燈片特效2013-03-03js trim函數(shù) 去空格函數(shù)與正則集錦
在javascript中處理文本框輸入值的時候,經(jīng)常要用到"去掉前后空白"的功能。用過jQuery的朋友都知道,jQuery提供了一個trim()這樣的功能函數(shù),可以很輕松幫我們實現(xiàn)這樣的效果。2009-11-11js實現(xiàn)簡易的單數(shù)字隨機抽獎(0-9)
這篇文章主要介紹了js實現(xiàn)簡易的單數(shù)字0-9隨機抽獎,可以控制抽取隨機數(shù)開始與停止,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2015-08-08