国产探花免费观看_亚洲丰满少妇自慰呻吟_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>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 金寨县| 柳州市| 东兴市| 同仁县| 大连市| 西藏| 中方县| 左权县| 江津市| 贞丰县| 三门峡市| 营口市| 钦州市| 陕西省| 台中县| 依安县| 颍上县| 孝昌县| 申扎县| 达州市| 湟中县| 建水县| 思茅市| 湘阴县| 涟水县| 东城区| 大姚县| 来安县| 当涂县| 阿拉尔市| 双桥区| 翁牛特旗| 康马县| 洮南市| 夏邑县| 汶川县| 天台县| 乾安县| 武定县| 乌拉特前旗| 孟村|