<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
最近有個微信小程式專案,需要將頁面轉為圖片。微信小程式提供的Api是wx.canvasToTempFilePath,這個方法是將畫布指定區域的內容匯出生成指定大小的圖片,但是我們是將頁面匯出圖片,所以可以使用wxml2canvas解決
npm init npm install wxml2canvas --save --production
npm init 是npm初始化,這個時候根據編譯器終端一路回車最終會生成一個package.json檔案
--production 是減少安裝與業務無關的包,減少專案的體積。
import Wxml2Canvas from 'wxml2canvas'
引入之後需要對微信開發者工具做出如下設定,否則引入之後會報錯
其次選擇微信開發者工具--》工具---》構建npm
這個時候就不會報錯了
首先在需要生成圖片的wxml檔案中建立canvas容器以及選擇生成圖片的範圍
<canvas canvas-id="myCanvas" class="myCanvas"></canvas> <view id="my-canvas" class="my_canvas> <view class="header my_draw_canvas"> <image class="headerImg my_draw_canvas" src="{{order.headerImg}}" data-type="image" data-url="{{order.headerImg}}"></image> <text class="headerTitle my_draw_canvas" data-type="text" data-text="您的訂單詳情">您的訂單詳情</text> </view> </view>
每個需要生成圖片的內容,需要註明型別。
text標籤對應的data-type='text',image標籤對應的data-type=‘image’
data-text=‘需要展示的文字’ data-url='需要展示的圖片'
其他的data-type型別可以參考https://github.com/liudongyun1215/wxml2canvas
這個連結裡面包含了許多設定項,就不一一列舉了,遇到問題的時候可以參考這個檔案
js檔案的方法
drawMyCanvas() { wx.showLoading() const that = this const query = wx.createSelectorQuery().in(this); query.select('#my-canvas').fields({ // 選擇需要生成canvas的範圍 size: true, scrollOffset: true }, data => { let width = data.width; let height = data.height; that.setData({ width, height }) setTimeout(() => { that.startDraw() }, 1500); }).exec() }, startDraw() { let that = this // 建立wxml2canvas物件 let drawMyImage = new Wxml2Canvas({ element: 'myCanvas', // canvas的id, obj: that, // 傳入當前元件的this width: that.data.width * 2, height: that.data.height * 2, background: '#141415', // 生成圖片的背景色 progress(percent) { // 進度 // console.log(percent); }, finish(url) { // 生成的圖片 wx.hideLoading() that.savePoster(url) }, error(res) { // 失敗原因 console.log(res); wx.hideLoading() } }, this); let data = { // 獲取wxml資料 list: [{ type: 'wxml', class: '.my_canvas .my_draw_canvas', // my_canvas要繪製的wxml元素根類名, my_draw_canvas單個元素的類名(所有要繪製的單個元素都要新增該類名) limit: '.my_canvas', // 要繪製的wxml元素根類名 x: 0, y: 0 }] } // 繪製canvas drawMyImage.draw(data, this); }, savePoster() { const that = this wx.saveImageToPhotosAlbum({ filePath: that.data.imgUrl, success: function() { wx.showToast({ title: '儲存成功', icon: 'none', duration: 1500 }); }, fail(err) { if (err.errMsg === "saveImageToPhotosAlbum:fail:auth denied" || err.errMsg === "saveImageToPhotosAlbum:fail auth deny" || err.errMsg === "saveImageToPhotosAlbum:fail authorize no response") { wx.showModal({ title: '提示', content: '需要您授權儲存相簿', showCancel: false, success: modalSuccess => { wx.openSetting({ success(settingdata) { if (settingdata.authSetting['scope.writePhotosAlbum']) { wx.saveImageToPhotosAlbum({ filePath: that.data.imgUrl, success: function () { wx.showToast({ title: '儲存成功', icon: 'success', duration: 2000 }) }, }) } else { wx.showToast({ title: '授權失敗,請稍後重新獲取', icon: 'none', duration: 1500 }); } } }) } }) } } }) },
使用wxml儲存圖片的時候,如果包含線上的圖片連結,需要在微信小程式後臺設定白名單,將線上連結的域名放置downloadFile合法域名裡,否則生成圖片的時候會報錯
還有就是頁面上的標籤需要有寬度,否則模擬器匯出正常,真機匯出樣式就會亂
到此這篇關於用wxml2canvas將微信小程式頁面轉為圖片的文章就介紹到這了,更多相關微信小程式頁面轉為圖片內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45