欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript在網(wǎng)頁中實現(xiàn)讀取剪貼板粘貼截圖功能

 更新時間:2014年06月07日 09:37:21   作者:  
這篇文章主要介紹了在網(wǎng)頁中實現(xiàn)讀取剪貼板粘貼截圖功能,即可以把剪貼板的截圖Ctrl+V粘貼到網(wǎng)頁的一個輸入框中,例如QQ截圖、旺旺截圖或者其它截圖軟件,需要的朋友可以參考下

見某網(wǎng)站的輸入框支持截屏粘貼的功能,覺得有點意思,于是將代碼扒出來分享下。

可惜,目前僅有高版本的 Chrome 瀏覽器支持這樣直接粘貼,其他瀏覽器目前為止還無法粘貼( IE11沒測試過 ),當(dāng)然這種增強型的用戶體驗功能有總比沒有好。

輸入框的結(jié)構(gòu)代碼:

復(fù)制代碼 代碼如下:

<input type="text" id="testInput" />

為輸入框綁定粘貼事件:

復(fù)制代碼 代碼如下:

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 鍵的截屏功能,或者其他第三方軟件提供的截屏功能。

復(fù)制代碼 代碼如下:

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 對其進行讀取了。

復(fù)制代碼 代碼如下:

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)了,可以使用以下源碼看看演示。

復(fù)制代碼 代碼如下:

<!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ù)項

    這篇文章主要介紹了JavaScript刪除有序數(shù)組中的重復(fù)項,主要解決有序數(shù)組?nums?,要求原地刪除重復(fù)出現(xiàn)的元素,使每個元素只出現(xiàn)一次,返回刪除后數(shù)組的新長的問題,下面實現(xiàn)操作,需要的小伙伴可以參考一下
    2022-03-03
  • javascript中的undefined 與 null 的區(qū)別  補充篇

    javascript中的undefined 與 null 的區(qū)別 補充篇

    在Javascript中有兩個值用來代表類似空值的概念,undefined和null,這兩個很容易被混淆,他們表示的是兩個不同的概念。
    2010-03-03
  • electron-builder書寫nsis腳本在安裝electron程序時安裝其他應(yīng)用程序(完美解決方案)

    electron-builder書寫nsis腳本在安裝electron程序時安裝其他應(yīng)用程序(完美解決方案)

    這篇文章主要介紹了electron-builder書寫nsis腳本在安裝electron程序時安裝其他應(yīng)用程序的解決方案,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-03-03
  • css transform 3D幻燈片特效實現(xiàn)步驟解讀

    css transform 3D幻燈片特效實現(xiàn)步驟解讀

    3D幻燈片特效想必大家以不在陌生至于表現(xiàn)形式一般都是拘泥于傳統(tǒng)接下來為大家介紹下使用css3 transform配合js以及html實現(xiàn)3D幻燈片特效
    2013-03-03
  • js trim函數(shù) 去空格函數(shù)與正則集錦

    js trim函數(shù) 去空格函數(shù)與正則集錦

    在javascript中處理文本框輸入值的時候,經(jīng)常要用到"去掉前后空白"的功能。用過jQuery的朋友都知道,jQuery提供了一個trim()這樣的功能函數(shù),可以很輕松幫我們實現(xiàn)這樣的效果。
    2009-11-11
  • JS如何實現(xiàn)頁面截屏功能實例代碼

    JS如何實現(xiàn)頁面截屏功能實例代碼

    這篇文章主要給大家介紹了關(guān)于JS如何實現(xiàn)頁面截屏功能的相關(guān)資料,文中主要利用了html2canvas和canvas繪制兩個方法來實現(xiàn),需要的朋友可以參考下
    2021-06-06
  • JS實現(xiàn)太極旋轉(zhuǎn)思路分析

    JS實現(xiàn)太極旋轉(zhuǎn)思路分析

    本文主要對JS實現(xiàn)太極旋轉(zhuǎn)的思路進行分析,步驟清晰,簡短的文字,深入的理解。需要的朋友可以看下
    2016-12-12
  • ie8本地圖片上傳預(yù)覽示例代碼

    ie8本地圖片上傳預(yù)覽示例代碼

    ie8本地圖片上傳預(yù)覽出現(xiàn)問題是因為限制瀏覽器造訪本地文件,所以用到濾鏡和div,下面有個不錯的示例,希望對大家有所幫助
    2014-01-01
  • js實現(xiàn)簡易的單數(shù)字隨機抽獎(0-9)

    js實現(xiàn)簡易的單數(shù)字隨機抽獎(0-9)

    這篇文章主要介紹了js實現(xiàn)簡易的單數(shù)字0-9隨機抽獎,可以控制抽取隨機數(shù)開始與停止,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2015-08-08
  • js事件冒泡實例分享(已測試)

    js事件冒泡實例分享(已測試)

    js事件冒泡實例:摘的網(wǎng)上的例子,但是他寫的有錯誤,自己改正了下,已驗證通過,感興趣的朋友可以參考下哈
    2013-04-04

最新評論