国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

javascript在網頁中實現讀取剪貼板粘貼截圖功能

2019-11-20 14:45:38
字體:
來源:轉載
供稿:網友

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

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

輸入框的結構代碼:

復制代碼 代碼如下:

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

為輸入框綁定粘貼事件:

復制代碼 代碼如下:

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

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

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

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

復制代碼 代碼如下:

input.addEventListener( 'paste', function( event ){
    // 添加到事件對象中的訪問系統剪貼板的接口
    var clipboardData = event.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 );
        }
    }
});

從剪貼板中取到了圖片數據,就可以用 FileReader 對其進行讀取了。

復制代碼 代碼如下:

var imgReader = function( item ){
    var file = item.getAsFile(),
        reader = new FileReader();

    // 讀取文件后將其顯示在網頁中
    reader.onload = function( e ){
        var img = new Image();

        img.src = e.target.result;
        document.body.appendChild( img );
    };

    // 讀取文件
    reader.readAsDataURL( file );
};


很短的代碼就實現了,可以使用以下源碼看看演示。

復制代碼 代碼如下:

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

<h1>利用 clipboardData 在網頁中實現截屏粘貼的功能</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>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 塔河县| 黄石市| 盘山县| 靖西县| 江门市| 封丘县| 温泉县| 涟水县| 徐闻县| 高雄县| 安达市| 衡阳市| 堆龙德庆县| 含山县| 浮梁县| 句容市| 阳原县| 阿克苏市| 辽源市| 修武县| 大名县| 祥云县| 湖南省| 乌海市| 东兴市| 舒兰市| 建水县| 长治县| 泰和县| 揭东县| 疏勒县| 山西省| 张家界市| 金昌市| 新竹市| 陵水| 洪江市| 洪泽县| 息烽县| 五华县| 林西县|