欧美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沒測試過 ),當然這種增強型的用戶體驗功能有總比沒有好。

輸入框的結(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>

相關文章

  • 無阻塞加載腳本分析[全]

    無阻塞加載腳本分析[全]

    script標簽的阻塞行為會對頁面性能產(chǎn)生負面影響,大多數(shù)瀏覽器在下載或執(zhí)行腳本的同時,會阻塞下載位于它之后的資源,也會阻塞渲染位于它之后的元素。
    2011-01-01
  • VsCode插件自動生成注釋插件koroFileHeader使用教程

    VsCode插件自動生成注釋插件koroFileHeader使用教程

    這篇文章主要介紹了VsCode插件自動生成注釋插件koroFileHeader使用教程,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • 如何制作浮動廣告 JavaScript制作浮動廣告代碼

    如何制作浮動廣告 JavaScript制作浮動廣告代碼

    如果有一定的JavaScript基礎,制作浮動廣告還是比較容易的,利用閑暇時間簡單制作了一個,感興趣的朋友可以參考下哦
    2012-12-12
  • JavaScript實現(xiàn)的九種排序算法

    JavaScript實現(xiàn)的九種排序算法

    這篇文章主要給大家介紹了關于利用JavaScript實現(xiàn)的九種排序算法的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-03-03
  • 基于BootStrap的前端分頁帶省略號和上下頁效果

    基于BootStrap的前端分頁帶省略號和上下頁效果

    這篇文章主要介紹了基于BootStrap的前端分頁帶省略號和上下頁效果,需要的朋友可以參考下
    2017-05-05
  • 去除html代碼里面的script正則方法

    去除html代碼里面的script正則方法

    下面小編就為大家?guī)硪黄コ齢tml代碼里面的script正則方法。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • window.returnValue使用方法示例介紹

    window.returnValue使用方法示例介紹

    returnValue是javascript中html的window對象的屬性,目的是返回窗口值,下面有個示例,大家可以感受下
    2014-07-07
  • 原生js代碼能實現(xiàn)call和bind嗎

    原生js代碼能實現(xiàn)call和bind嗎

    這篇文章主要介紹了原生js代碼能實現(xiàn)call和bind嗎,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-07-07
  • Bootstrap3 Grid system原理及應用詳解

    Bootstrap3 Grid system原理及應用詳解

    這篇文章主要為大家詳細介紹了Bootstrap3 Grid system原理及應用,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • Javascript判斷圖片尺寸大小實例分析

    Javascript判斷圖片尺寸大小實例分析

    通常我們判斷js圖片大小都是利用images對象,然后再用attr來獲取圖片地址再進行判斷就可以了。這篇文章主要介紹了Javascript判斷圖片尺寸大小的實例,需要的朋友可以參考下
    2014-06-06

最新評論