以前我們只能透過其他的截圖工具來截取影像。現代瀏覽器的功能已經越來越強,隨著H5的逐漸普及,瀏覽器本身就可以截圖啦。 html2canvas就是這樣一款前端插件,它的原理是將Dom節點在Canvas裡邊畫出來。雖然很方便,但有以下限制:
由於我的使用場景很簡單,記錄一下異常訊息,並且異常頁面也是由自己定義的,那麼html2canvas 就足夠使用了。
第一次用html2canvas,目的就是想把整個頁面截圖下來產生一張圖片給使用者保存
下面我們先來看看HTML渲染出來的是啥樣子的
HTML渲染出來的圖片可以看到上面的圖片是有圓角效果的,但是當我用html2canvas來轉換圖片操作的時候,發現圖片圓角效果沒失效了。
變成了上面這個樣子。想了很多解決方案,後來決定把後面的圓角做成一張背景圖片,中間圓的部分背景透明,然後透過絕對定位覆蓋到原來的圖片上面,相當於是一個遮罩這種效果。
當然,遮罩圖片的DOM節點必須在需要圓角圖片的下面,類似於
<div class=avatar_img fl><div class=avatar_img fl> <img src= id=you class=avatar_pp fl /><!--需要圓角的原始圖片--> <img src=/template/images/avatar .png class=img-responsive style=position: absolute;><!--遮罩圖片--></div>
生成出來就是正常的樣子了
<div class=avatar_img fl><div class=avatar_img fl> <img src= id=you class=avatar_pp fl /><!--需要圓角的原始圖片--> <img src=/template/images/avatar .png class=img-responsive style=position: absolute;><!--遮罩圖片--></div>複製程式碼