(題圖:梵高-橄欖樹)html
由於工做緣由,如今有一個需求就是須要用戶使用QQ或者微信複製一張截圖後,在div中直接粘貼這張圖片,而不是採用上傳的方式。相似咱們在使用QQ微信時直接粘貼截圖的操做,這個要怎麼用js來實現呢?前端
咱們能夠利用 Clipboard
這個接口API 來實現。ajax
根據在MDN上的定義,Clipboard接口提供了一種讀寫操做系統剪貼板的方式。這樣咱們就能夠獲取剪貼板的內容,而後經過js插入到某個元素中。後端
具體Clipboard API的MDN連接以下: https://developer.mozilla.org/zh-CN/docs/Web/API/Clipboard瀏覽器
在瀏覽器兼容性上面,能夠看到大致上,經常使用的瀏覽器都支持,不過IE就就只能是IE11及以上了。服務器
直接上代碼了。微信
// 將粘貼事件綁定到 document 上 document.addEventListener("paste", function (e) { let items = event.clipboardData && event.clipboardData.items; let file = null; if (items && items.length) { // 檢索剪切板items中類型帶有image的 for (var i = 0; i < items.length; i++) { if (items[i].kind === 'file') { // 或者 items[i].type.indexOf('image') !== -1 file = items[i].getAsFile(); // 此時file就是剪切板中的圖片文件 break; } } } }, false);
若是複製的是文本的話,能夠這樣或者粘貼板的文本內容:app
let text = null; if (items && items.length) { // 檢索剪切板items for (let i = 0; i < items.length; i++) { // ... if (items[i].kind === 'string') { text = event.clipboardData.getData('Text'); // 獲取文本內容 break; } } }
獲取到的是文本內容,能夠直接在前端顯示。函數
若是是圖片的話,就須要上傳到服務器,而後再在前端預覽,具體操做往下看。ui
若是隻是圖片,能夠直接使用ajax將file保存到服務器便可。
或者經過 FormData 對象進行ajax上傳。
let formData = new FormData(); formData.append('file', file); // 將formData上傳便可
下次下載以後,經過get方法再次獲取到file文件。
let file = formData.get('file');
上傳成功後,咱們須要及時在前端看到這個圖片,這個能夠經過FileReader
對象就能夠作到。
let reader = new FileReader(); reader.readAsDataURL(file); reader.onload = function (e) { let img = document.createElement("img"); img.src = e.target.result; document.body.appendChild(img); // 將圖片插入body中 }
或者在html中定義好<img>
標籤,直接修改圖片的src便可
reader.onload = function (e) { let img = document.getElementByName("img")[0]; img.src = e.target.result; }
注意:這裏
e.target.result
獲得的是圖片的Base64格式的地址。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <meta http-equiv="X-UA-Compatible" content="ie=edge" /> <title>Document</title> </head> <body> <script> // 將粘貼事件綁定到 document 上 document.addEventListener( 'paste', function(e) { let items = event.clipboardData && event.clipboardData.items; let file = null; if (items && items.length) { for (let i = 0; i < items.length; i++) { if (items[i].type.indexOf('image') !== -1) { file = items[i].getAsFile(); // 此時file就是剪切板中的圖片文件 break; } } } // 若是須要上傳後端,只需使用ajax將file上傳便可。 // 這裏是ajax上傳操做... if (file.size === 0) { return; } // 上傳成功後,在回調函數中設置前端預覽 let reader = new FileReader(); reader.readAsDataURL(file); reader.onload = function(e) { let img = document.createElement('img'); img.src = e.target.result; document.body.appendChild(img); }; }, false ); </script> </body> </html>
能夠直接複製上面demo代碼進行實驗。
(啾咪 ^.< )