Dalam artikel sebelumnya "Analisis Ringkas Interaksi antara Program Mini WeChat dan Web (Perkongsian Kod) ", saya akan memberi anda pemahaman tentang interaksi antara Program Mini WeChat dan web. Artikel berikut akan memberi anda pemahaman tentang cara menyimpan imej pada halaman applet WeChat Rakan-rakan yang memerlukan saya harap ia akan membantu anda.
Simpan gambar dalam webview
program mini. Kerana WeChat js-sdk
tidak menyediakan saveImageToPhotosAlbum
kaedah
untuk lebih banyak interaksi web
dengan program mini, sila lihat di sini
Muat pertama memuatkan WeChatjs-sdk
<script src="https://res.wx.qq.com/open/js/jweixin-1.6.0.js"></script>
1 Tukar imej kepada html
melalui base64
, dan kemudian hantar ke program Mini postmessage
let img = new Image(); img.src = "xxxx"; //这里是图片的src img.crossOrigin = "anonymous"; //The opeartaion is insecure . 其它跨域的问题 自行代理解决 img.onload = function () { let canvas = document.createElement("canvas"); canvas.width = img.width; canvas.height = img.height; let ctx = canvas.getContext("2d"); ctx.drawImage(this, 0, 0); let imgBase64Data = canvas.toDataURL("image/jpeg", 1); //这里就拿到了base64 wx.miniProgram.postMessage({ data: { imgData: imgBase64Data, // 刚才拿到的base64 数据 }, }); };
2. Program mini memantau dan mendapatkan data postmessage
imej. base64
// wxml < web - view src = "http://www.chuchur.com/save-image" bindmessage = "getMessage" > < /web-view> // js Page({ data: { imageData: null } getMessage(e) { this.setData({ imageData: e.detail.data[0].imgData }) } })
3 Simpan gambar ke album (dalam program mini)
Oleh kerana anda mendapat data gambar, anda perlu untuk menyimpannya dahulu Simpan sebagai fail imej. base64
wx.getFileSystemManager().writeFile({ filePath: wx.env.USER_DATA_PATH + "/qrcode.png", //这里先把文件写到临时目录里. data: this.data.imageData.slice(22), // 注意这里 encoding: "base64", success: (res) => { console.log("success"); }, fail: (error) => { console.log(error); }, });
base64 yang ditulis oleh writeFile getFileSystemManager tidak termasuk bait pengepala imej. Jadi anda perlu membuang data:image/jpeg;base64, dan tunggu aksaraSetelah anda mempunyai laluan fail, anda boleh menyimpannya ke album
wx.saveImageToPhotosAlbum({ filePath: wx.env.USER_DATA_PATH + "/qrcode.png", //这是把临时文件 保存到 相册, 收工 success: (res) => { wx.showToast({ title: "保存成功!", }); }, fail: (error) => { console.log(error); }, });
dalam h5
akan menyerahkan maklumat serta-merta, program mini tidak akan menerimanya serta-merta Fungsi mendengar pada program mini postMessage
hanya akan dicetuskan dan dikumpulkan pada masa tertentu Mesej: Iaitu, semua mesej webview
hanya boleh dicetuskan selepas ia dikongsi atau kitaran hayat postMessage
tamat. Ia ialah baris gilir mesej: webview
getMessage: function(e) { if (e.type === 'message' && e.detail && e.detail.data && e.detail.data.length > 0) { e.detail.data.forEach(function(dataItem) { if (dataItem.type === 'qbreport' && dataItem.key) { // todo: yourFn(dataItem.key) } }) } }
Jadi , kita boleh mencetuskan acara pemulangannya serta-merta apabila melaksanakan simpan.
function() { // 此处省略 wx.miniProgram.postMessage({ data: { xxx: 'aaa' } }) wx.miniProgram.navigateBack({ delta: 1 }) //注意这里. }
Kod terminal: html
webchat webview save image <script src="https://res.wx.qq.com/open/js/jweixin-1.6.0.js"></script> <script> function saveImage() { let img = new Image() img.src = 'xxxx' //这里是图片的src img.crossOrigin = 'anonymous' //The opeartaion is insecure , 其他跨域问题自行代理解决. img.onload = function() { let canvas = document.createElement('canvas') canvas.width = img.width canvas.height = img.height let ctx = canvas.getContext('2d') ctx.drawImage(this, 0, 0) let imgBase64Data = canvas.toDataURL('image/jpeg', 1) //这里就拿到了base64 wx.miniProgram.postMessage({ data: { imgData: imgBase64Data // 刚才拿到的base64 数据 } }) wx.miniProgram.navigateBack({ delta: 1 }) //注意这里. } } </script>
// wxml < web - view src = "http://www.chuchur.com/save-image" bindmessage = "getMessage" > < /web-view> // js Page({ getMessage(e) { let img = e.detail.data[0].imgData wx.getFileSystemManager().writeFile({ filePath: wx.env.USER_DATA_PATH + '/qrcode.jpeg', //这里先把文件写到临时目录里. data: img.slice(22), //注意这里 encoding: 'base64', success: res => { console.log('success') wx.saveImageToPhotosAlbum({ filePath: wx.env.USER_DATA_PATH + '/qrcode.jpeg', //这是把临时文件 保存到 相册, 收工 success: res => { wx.showToast({ title: '保存成功!' }) }, fail: error => { console.log(error) } }) }, fail: error => { console.log(error) } }) } })
Menyimpan gambar jauh
wx.showLoading({ title: "正在下载图片... ", mask: !1 }) wx.downloadFile({ url: '填写一个远程的图片链接', success: function(t) { wx.showLoading({ title: "正在保存图片", mask: !1 }) wx.saveImageToPhotosAlbum({ filePath: t.tempFilePath, success: function() { wx.showModal({ title: "自定义提示信息", content: "保存成功", showCancel: !1 }); }, fail: function(t) { wx.showModal({ title: "图片保存失败", content: t.errMsg, showCancel: !1 }); }, complete: function(t) { wx.hideLoading(); } }); }, fail: function(t) { wx.showModal({ title: "图片下载失败", content: t.errMsg, showCancel: !1 }); }, complete: function(t) { wx.hideLoading(); } }))
Atas ialah kandungan terperinci Analisis mendalam untuk menyimpan imej yang dilaksanakan dalam halaman applet WeChat (dengan kod). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!