html2canvas踩坑記

前端程序員墓志銘:永遠(yuǎn)不要使用Alpha版的插件

最近寫(xiě)一個(gè)活動(dòng)項(xiàng)目需要將一個(gè)HTML頁(yè)面轉(zhuǎn)為圖片,之前一直是后臺(tái)采用拼接的方式完成,然而現(xiàn)在遇到一個(gè)問(wèn)題,Java拼接的HTML在生成圖片時(shí)由于里面的文字太長(zhǎng)沒(méi)法自動(dòng)換行,想使用css的強(qiáng)制換行

#wrap{word-break:break-all; width:200px;}
或者
#wrap{word-wrap:break-word; width:200px;}
<div id="wrap">abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111</div>

均沒(méi)有實(shí)現(xiàn)想要的換行效果,不知道有沒(méi)有哪位朋友遇到過(guò)類(lèi)似的情況,歡迎分享一下.
總之我使用css是沒(méi)有走通,于是選擇使用html2canvas.js這個(gè)插件在前端生成圖片.
在介紹這個(gè)插件前先科普一下軟件的版本號(hào).

Alpha:是內(nèi)部測(cè)試版,一般不向外部發(fā)布,會(huì)有很多Bug.一般只有測(cè)試人員使用铭若。
Beta:也是測(cè)試版奶栖,這個(gè)階段的版本會(huì)一直加入新的功能。在Alpha版之后推出。
α礼旅、β、λ常用來(lái)表示軟件測(cè)試過(guò)程中的三個(gè)階段缘琅,α是第一階段,一般只供內(nèi)部測(cè)試使用褒颈;β是第二個(gè)階段,已經(jīng)消除了軟件中大部分的不完善之處励堡,但仍有可能還存在缺陷和漏洞谷丸,一般只提供給特定的用戶群來(lái)測(cè)試使用;λ是第三個(gè)階段应结,此時(shí)產(chǎn)品已經(jīng)相當(dāng)成熟刨疼,只需在個(gè)別地方再做進(jìn)一步的優(yōu)化處理即可上市發(fā)行。 

這款插件最坑的地方就是將Alpha版放了出來(lái),而我剛好就選擇了最新的版本

踩坑版本

以后使用插件就應(yīng)該看官網(wǎng)demo引入哪個(gè)版本的插件我們就使用哪個(gè),要不這坑進(jìn)去了真的很難出來(lái).

行了,廢話不多說(shuō)了,直接進(jìn)入正題

使用哪種語(yǔ)法

首先我們整體了解一下html2canvas.js這個(gè)插件,大家可以到官網(wǎng)上查閱文檔
http://html2canvas.hertzen.com/documentation.html
或者參閱這篇文章
http://www.reibang.com/p/6a07e974a7e8

引入html2canvas.js文件,我這里使用的是0.4.1版本(從1.0版降下來(lái)的),
上面兩個(gè)鏈接分別對(duì)應(yīng)兩種語(yǔ)法格式

html2canvas(document.getElementById('id'))
.then(function(canvas) {document.body.appendChild(canvas);});

但是我在使用這種語(yǔ)法報(bào)錯(cuò),然后參考官網(wǎng)的文檔寫(xiě)法

html2canvas(document.getElementById("target"), {
  allowTaint: true, //允許污染
  taintTest: true, //在渲染前測(cè)試圖片(沒(méi)整明白有啥用)
  useCORS: true, //使用跨域(當(dāng)allowTaint為true時(shí)這段代碼沒(méi)什么用,下面解釋)
  background: "#fff",
  onrendered: function (canvas) {
    imgBlob = canvas.toDataURL('image/jpeg', 1.0); //將圖片轉(zhuǎn)為base64
    imgBlob = imgBlob.toString().substring(imgBlob.indexOf(",") + 1);//截取base64以便上傳
  }
});

有關(guān)允許canvas污染的問(wèn)題可以參考此文
https://developer.mozilla.org/zh-CN/docs/Web/HTML/CORS_enabled_image

其實(shí)這里的代碼很好理解,傳參數(shù)進(jìn)去,剩下的就交給插件去完成,我們只要拿到base64流就可以了.
上文中說(shuō)useCORS沒(méi)有起作用我們看看源碼就明白為什么沒(méi)起作用了

...
} else if ( isSameOrigin( src ) || options.allowTaint ===  true ) {
  ...
} else if ( supportCORS && !options.allowTaint && options.useCORS ) {
  ...
};
 ...

這里我們看到這兩個(gè)判斷是互相矛盾的options.allowTaint為true那么!options.allowTaint永遠(yuǎn)為false

allowTaint該設(shè)置成true還是false

allowTaint

點(diǎn)擊查看

因?yàn)?code>allowTaint表示是否允許被污染,而被污染的canvas是沒(méi)法使用toDataURL()轉(zhuǎn)base64流的,但是我們這需要base64,所有allowTaint需要被設(shè)置為false
當(dāng)設(shè)置為true時(shí),會(huì)報(bào)這樣的錯(cuò)誤

Uncaught DOMException: Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported.
    at Object.onrendered (http://127.0.0.1:8080/:142:32)
    at Object.options.complete (http://127.0.0.1:8080/js/html2canvas.js:2711:15)
    at start (http://127.0.0.1:8080/js/html2canvas.js:2215:17)
    at Image.img.onload (http://127.0.0.1:8080/js/html2canvas.js:2352:7)

useCORS是干嘛的

當(dāng)useCORSfalse時(shí)我們發(fā)現(xiàn)

看到了希望

這是什么鬼?圖片去哪了?不過(guò)已經(jīng)有突破了,圖片出來(lái)了,現(xiàn)在我們需要找到圖片不加載的問(wèn)題
我們把useCORS設(shè)置成true時(shí)是什么效果呢?
然鵝效果還是和上圖一樣,但是這次控制臺(tái)出現(xiàn)了錯(cuò)誤

Access to Image at 'http://web.rrzuzu.com/WebStatic/rry-activity/target/images/bj.jpg' from origin 'http://127.0.0.1:8080' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://127.0.0.1:8080' is therefore not allowed access.
...

由于公司里面將圖片資源放在OSS里,這里涉及到跨域的問(wèn)題造成圖片沒(méi)法加載,好了,找到問(wèn)題的所在我們就能很快的解決了,將資源放到同一域名下(OSS設(shè)置允許跨域不知道能不能解決,后期會(huì)再次嘗試一下)
再來(lái)看看解決后的效果


這里寫(xiě)圖片描述

哈哈,大功告成!
哦,對(duì)了,關(guān)于布局的坑我還得提議下

布局

布局一開(kāi)始想到的是使用display: none讓元素隱藏,當(dāng)使用這種方法后發(fā)現(xiàn)生成的什么也沒(méi)有.
沒(méi)辦法,使用position: absolute讓元素跑到視野之外總行了吧top: -9999px;

image.png

納尼,一片漆黑,查了些資料發(fā)現(xiàn)生成視野內(nèi)圖片,那么top: 9999px行不行?事實(shí)證明是可以的,這樣設(shè)置總感覺(jué)心理不踏實(shí),萬(wàn)一body的高度為100000px怎么辦?接著有嘗試使用left和right,均沒(méi)什么卵用,這時(shí)想到使用圖層高度,OK,那就試試吧,top: 0px; z-index: -1;完美解決
等等,我們現(xiàn)在只是在模擬器里面測(cè)試,還沒(méi)有在真機(jī)上測(cè)試,當(dāng)在真機(jī)上看到的效果時(shí)我的內(nèi)心是崩潰的,手機(jī)不支持overflow: hidden;屬性WTF,還得想辦法此時(shí)查到了一些資料:

禁止蒙層底部頁(yè)面跟隨滾動(dòng)http://mp.weixin.qq.com/s/704rUV3U0BwQuVea1Iwe4Q

最簡(jiǎn)單的方法時(shí)使用position: fixed;這方法很好,解決了下層頁(yè)面沒(méi)被隱藏和軟鍵盤(pán)彈出后頁(yè)面的問(wèn)題,然而生成的圖片沒(méi)法顯示,依舊是一片漆黑,總之試了很多次,只要在body使用fixed就別想生成圖片,最后發(fā)現(xiàn)只用css是沒(méi)法實(shí)現(xiàn)的了,于是結(jié)合js一起操作
最后使用fixed操作同級(jí)的container讓其在軟件盤(pán)彈出或消失的時(shí)候始終將元素保持bottom: 0;,再讓頁(yè)面沒(méi)法滾動(dòng)

$('.container')[0].addEventListener('touchmove', e => {
    e.preventDefault()
}, false)

總結(jié)一句需要生成的元素得在fixed的上層,并且不能讓頁(yè)面滾動(dòng)
至此,功能算是完成了,改踩的坑也踩得差不多了,以后遇到問(wèn)題再繼續(xù)更新

小插曲

當(dāng)時(shí)我在生成圖片的時(shí)候獲取了返回的圖片地址,但是有時(shí)候服務(wù)器并沒(méi)有返回圖片地址,而我需要將圖片地址傳遞到另外的一個(gè)頁(yè)面,所以需要判斷一下,在有地址的時(shí)候再執(zhí)行ajax傳遞并跳轉(zhuǎn)

success: function (res) {
  imgUrl = res;
  //提交表單
  if (imgUrl) {
    $(".form").ajaxSubmit({
      ...
      success: function (data) {
        if (data.code == 12000) {
          debugger;
          window.location. + imgUrl;
        }
      }
    });
  }
 }

如果有朋友對(duì)html2canvas.js有興趣,想查看我的項(xiàng)目源碼的可以到github上拉取,如果大家對(duì)此插件有更深刻的理解歡迎留言

最后再多說(shuō)一句:人人搖是個(gè)啥?掃碼你就知道啦

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末鹅龄,一起剝皮案震驚了整個(gè)濱河市揩慕,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌扮休,老刑警劉巖迎卤,帶你破解...
    沈念sama閱讀 216,651評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異玷坠,居然都是意外死亡止吐,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)侨糟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)碍扔,“玉大人,你說(shuō)我怎么就攤上這事秕重〔煌” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,931評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵溶耘,是天一觀的道長(zhǎng)二拐。 經(jīng)常有香客問(wèn)我,道長(zhǎng)凳兵,這世上最難降的妖魔是什么百新? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,218評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮庐扫,結(jié)果婚禮上饭望,老公的妹妹穿的比我還像新娘。我一直安慰自己形庭,他們只是感情好铅辞,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,234評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著萨醒,像睡著了一般斟珊。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上富纸,一...
    開(kāi)封第一講書(shū)人閱讀 51,198評(píng)論 1 299
  • 那天囤踩,我揣著相機(jī)與錄音旨椒,去河邊找鬼。 笑死堵漱,一個(gè)胖子當(dāng)著我的面吹牛综慎,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播怔锌,決...
    沈念sama閱讀 40,084評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼寥粹,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了埃元?” 一聲冷哼從身側(cè)響起涝涤,我...
    開(kāi)封第一講書(shū)人閱讀 38,926評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎岛杀,沒(méi)想到半個(gè)月后阔拳,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,341評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡类嗤,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,563評(píng)論 2 333
  • 正文 我和宋清朗相戀三年糊肠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片遗锣。...
    茶點(diǎn)故事閱讀 39,731評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡货裹,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出精偿,到底是詐尸還是另有隱情弧圆,我是刑警寧澤,帶...
    沈念sama閱讀 35,430評(píng)論 5 343
  • 正文 年R本政府宣布笔咽,位于F島的核電站搔预,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏叶组。R本人自食惡果不足惜拯田,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,036評(píng)論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望甩十。 院中可真熱鬧船庇,春花似錦、人聲如沸枣氧。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,676評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)达吞。三九已至,卻和暖如春荒典,著一層夾襖步出監(jiān)牢的瞬間酪劫,已是汗流浹背吞鸭。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,829評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留覆糟,地道東北人刻剥。 一個(gè)月前我還...
    沈念sama閱讀 47,743評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像滩字,于是被迫代替她去往敵國(guó)和親造虏。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,629評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理麦箍,服務(wù)發(fā)現(xiàn)漓藕,斷路器,智...
    卡卡羅2017閱讀 134,652評(píng)論 18 139
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,079評(píng)論 25 707
  • 點(diǎn)擊查看原文 Web SDK 開(kāi)發(fā)手冊(cè) SDK 概述 網(wǎng)易云信 SDK 為 Web 應(yīng)用提供一個(gè)完善的 IM 系統(tǒng)...
    layjoy閱讀 13,758評(píng)論 0 15
  • 問(wèn)題:關(guān)于財(cái)富方面的匱乏意識(shí)引發(fā)的恐懼怎么辦? 溫雅解答:剛才有咨詢(xún)我的家人問(wèn)到诀蓉。我以文字發(fā)在群里方便大家看:匱乏...
    溫雅老師閱讀 677評(píng)論 0 1
  • 文/七毛是我 <一> 小四爺是我爸的親弟弟栗竖,老家那邊叫“爺”不叫“叔”,他排行老四渠啤,又是最小的兒子狐肢,所以我們都叫他...
    七毛是我閱讀 3,472評(píng)論 38 85