亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

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

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

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

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

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

為輸入框綁定粘貼事件:

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

var input = document.getElementById( 'testInput' );

input.addEventListener( 'paste', function( event ){
    // dosomething...
});

粘貼事件的 Event 接口對(duì)象提供了一個(gè) clipboardData 接口,該接口就保存了系統(tǒng)剪貼板中的數(shù)據(jù),如上面所說,目前只有高版本的 Chrome 瀏覽器能直接訪問系統(tǒng)剪貼板的數(shù)據(jù)。這就給截屏后保存到剪貼板中的圖片于網(wǎng)頁直接進(jìn)行交互提供了一個(gè)入口。

這里所說的截屏,就是 QQ 提供的截屏或者系統(tǒng)自帶的 PrtScn 鍵的截屏功能,或者其他第三方軟件提供的截屏功能。

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

input.addEventListener( 'paste', function( event ){
    // 添加到事件對(duì)象中的訪問系統(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 對(duì)其進(jìn)行讀取了。

復(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 );
};


很短的代碼就實(shí)現(xiàn)了,可以使用以下源碼看看演示。

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

<!DOCTYPE HTML>
<html lang="en-US">
<head>
<meta charset="UTF-8">
<title>利用 clipboardData 在網(wǎng)頁中實(shí)現(xiàn)截屏粘貼的功能</title>
<style type="text/css">
#box{ width:200px; height:200px; border:1px solid #ddd; }
</style>
</head>
<body>

<h1>利用 clipboardData 在網(wǎng)頁中實(shí)現(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)文章

最新評(píng)論