javascript - 如何不使用插件用canvas將div中的內(nèi)容轉(zhuǎn)為一張圖片。
問(wèn)題描述
網(wǎng)上不少人提到用canvas,但是關(guān)鍵的內(nèi)容轉(zhuǎn)換部分好像大多是用插件去輔助完成,而找到的僅有的一個(gè)不依賴插件的示例卻又運(yùn)行出錯(cuò)。想請(qǐng)教大神如何不使用插件將p中的內(nèi)容轉(zhuǎn)為一張圖片~~
問(wèn)題解答
回答1:不是說(shuō)用插件不可以,而是說(shuō),你知不知道,插件它內(nèi)部又是用的什么原理實(shí)現(xiàn)的呢?是否明白大概的原理和邏輯?插件并不能算一種實(shí)現(xiàn)方法啊!插件只是一種解決方案!或許你自己寫(xiě),實(shí)現(xiàn)方法用的和插件是一樣的!
回到問(wèn)題,把p轉(zhuǎn)成圖片,這個(gè)工作是否可行,工作量是多少,你是否有意識(shí)?從可行性上將,有插件可以實(shí)現(xiàn),那說(shuō)明在現(xiàn)有前端領(lǐng)域是可行的。那實(shí)現(xiàn)原理是什么呢?
你首先要想到的是,前端代碼是依托在瀏覽器里運(yùn)行的。那好,我們第一個(gè)要想到的是,瀏覽器是否直接提供里這種 API 呢?瀏覽器 API 找什么? 找 BOM DOM的文檔啊。據(jù)我所知,有firefox好像可以把某個(gè)節(jié)點(diǎn)當(dāng)某個(gè)元素的背景,在 css 中發(fā)明了 background: -moz-element() 的語(yǔ)法,并沒(méi)有類似截屏的 API。
你也提到了 canvas。做開(kāi)發(fā)的,最好要保持好奇心。你可以很淺地去了解,這種插件他們是如何完成的。你沒(méi)必要知道完成這個(gè)功能的所有細(xì)節(jié),但是你要知道這個(gè)實(shí)現(xiàn)原理為什么可行。
OK,canvas怎么畫(huà)p呢?canvas給了你處理像素的能力,理論上你可以畫(huà)任何東西。插件的做法就是讀取p以及p的style樣式,自己在canvas上畫(huà)出p,然后遞歸p的子節(jié)點(diǎn)。好,這個(gè)工作簡(jiǎn)單嗎?肯定不簡(jiǎn)單!哪個(gè)大神可以徒手造輪子?然后把造出來(lái)的輪子貼到這個(gè)問(wèn)題地下給你做回答?哪個(gè)大神能把你教會(huì)?
你和大神的差距不在于大神能徒手寫(xiě) html2canvas,而是大神遇到問(wèn)題能清晰地分析。
當(dāng)然,我也不是大神,只是看到這種問(wèn)題就忍不住要吐槽。
回答2:你需要先將p轉(zhuǎn)成svg,然后再將svg轉(zhuǎn)成canvas,不過(guò)中間有幾個(gè)注意的點(diǎn):
1.html轉(zhuǎn)svg的時(shí)候請(qǐng)注意其中不能有像input這樣的控件元素,不然會(huì)轉(zhuǎn)失敗;
2.在html轉(zhuǎn)svg的過(guò)程中需要先將html元素的樣式全部遍歷轉(zhuǎn)成內(nèi)聯(lián)樣式然后再轉(zhuǎn)svg,不然你可能看到一片空白。
回答3:其實(shí)你說(shuō)的這種需求。可以轉(zhuǎn)個(gè)彎
可以先截圖 然后粘貼到input中 綁定一個(gè)input的粘貼 paste 事件然后 event.clipboardData.items 用 var img = new Image() 讀出來(lái)最后放在 canvas 里面 用context.dramImage(img,0,0) var url = context.toDataURL(’image/png’) 這不就是一個(gè)圖片了嗎 最后用 const a = document.createElement(’a’) a.setAttribute(’download’,true) a.setAttribute(’href’,url) a.click() 圖片就下載下來(lái)了 :)
相關(guān)文章:
1. MySQL客戶端吃掉了SQL注解?2. php自學(xué)從哪里開(kāi)始?3. mysql - AttributeError: ’module’ object has no attribute ’MatchType’4. 數(shù)據(jù)庫(kù) - MySQL 單表500W+數(shù)據(jù),查詢超時(shí),如何優(yōu)化呢?5. 求大神幫我看看是哪里寫(xiě)錯(cuò)了 感謝細(xì)心解答6. python - Django分頁(yè)和查詢參數(shù)的問(wèn)題7. javascript - 圖片能在網(wǎng)站顯示,但控制臺(tái)仍舊報(bào)錯(cuò)403 (Forbidden)8. javascript - 百度echarts series數(shù)據(jù)更新問(wèn)題9. phpstady在win10上運(yùn)行10. python小白的基礎(chǔ)問(wèn)題 關(guān)于while循環(huán)的嵌套
