小程序?qū)崿F(xiàn)長按保存圖片的方法
微信瀏覽器打開h5頁面如果是img標(biāo)簽的話,長按會(huì)彈出保存圖片的選項(xiàng)。但是微信小程序里面不可以。需要自己寫這個(gè)功能。這個(gè)功能有兩個(gè)點(diǎn),一個(gè)是長按,一個(gè)是保存圖片到本地。
1,、微信小程序提供了長按的事件,叫 bindlongpress
2、微信小程序同樣提供了保存圖片的接口,是 wx.saveImageToPhotosAlbum()
弄清楚了,我們可以開始做這個(gè)功能了,首先寫wxml
<image src="{{url}}" data-url="{{url}}" bindlongpress="saveImage"></image>
然后就是js代碼了
Page({
/**
* 頁面的初始數(shù)據(jù)
*/
data: {
url:"https://wechat.weixinzjit.com/costa/public/uploads/images/20190109/67b16149693920598435315fd0d5ab3e.jpg"
},
// 長按保存圖片
saveImg(e){
let url = e.currentTarget.dataset.url;
wx.saveImageToPhotosAlbum({
filePath:url,
success(res) {
console.log(res);
},
fail(res){
console.log(res);
}
})
}
})
這樣寫感覺沒問題,但是不行,為什么,看下面文檔說明。

遇到了兩個(gè)問題:
1、需要授權(quán)
2、路徑不能是網(wǎng)絡(luò)路徑
一個(gè)問題一個(gè)問題解決,首先長按之后,不去保存圖片,先去判斷用戶是否授權(quán),這個(gè)接口就不多講了,之前寫過。
直接貼上代碼
wx.getSetting({
success: (res) => {
if (!res.authSetting['scope.writePhotosAlbum']) {
wx.authorize({
scope: 'scope.writePhotosAlbum',
success:()=> {
// 同意授權(quán)
},
fail: (res) =>{
console.log(res);
}
})
}else{
// 已經(jīng)授權(quán)了
}
},
fail: (res) =>{
console.log(res);
}
})
授權(quán)問題解決了以后,要處理另外一個(gè)問題,就是圖片不能是網(wǎng)絡(luò)路徑。這個(gè)時(shí)候我們可以用到另外一個(gè)接口,叫 wx.getImageInfo()

通過文檔看到,這個(gè)接口是可以接收網(wǎng)絡(luò)路徑的,返回的是本地路徑。所以我們先用這個(gè)接口把網(wǎng)絡(luò)路徑轉(zhuǎn)化一下,再拿去給wx.saveImageToPhotosAlbum用。
wx.getImageInfo({
src: url,
success:(res)=> {
let path = res.path;
wx.saveImageToPhotosAlbum({
filePath:path,
success(res) {
console.log(res);
},
fail:(res)=>{
console.log(res);
}
})
},
fail:(res)=> {
console.log(res);
}
})
所以整體的代碼是這樣子的
Page({
data: {
url:"https://wechat.weixinzjit.com/costa/public/uploads/images/20190109/67b16149693920598435315fd0d5ab3e.jpg"
},
// 長按保存圖片
saveImg(e){
let url = e.currentTarget.dataset.url;
//用戶需要授權(quán)
wx.getSetting({
success: (res) => {
if (!res.authSetting['scope.writePhotosAlbum']) {
wx.authorize({
scope: 'scope.writePhotosAlbum',
success:()=> {
// 同意授權(quán)
this.saveImg1(url);
},
fail: (res) =>{
console.log(res);
}
})
}else{
// 已經(jīng)授權(quán)了
this.saveImg1(url);
}
},
fail: (res) =>{
console.log(res);
}
})
},
saveImg1(url){
wx.getImageInfo({
src: url,
success:(res)=> {
let path = res.path;
wx.saveImageToPhotosAlbum({
filePath:path,
success:(res)=> {
console.log(res);
},
fail:(res)=>{
console.log(res);
}
})
},
fail:(res)=> {
console.log(res);
}
})
},
})
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
為什么JavaScript中0.1 + 0.2 != 0.3
這篇文章主要給大家介紹了關(guān)于為什么JavaScript中0.1 + 0.2 != 0.3的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
js實(shí)現(xiàn)點(diǎn)擊注冊(cè)按鈕開始讀秒倒計(jì)時(shí)的小例子
js實(shí)現(xiàn)點(diǎn)擊注冊(cè)按鈕開始讀秒倒計(jì)時(shí)的小例子,需要的朋友可以參考一下2013-05-05
JavaScript給數(shù)組添加元素的6個(gè)方法
本文主要介紹了JavaScript給數(shù)組添加元素的6個(gè)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
Javascript刪除指定元素節(jié)點(diǎn)的方法
這篇文章主要介紹了使用Javascript刪除指定元素節(jié)點(diǎn)的方法,通俗易懂,需要的朋友可以參考下。2016-06-06
微信小程序開發(fā)之a(chǎn)nimation循環(huán)動(dòng)畫實(shí)現(xiàn)的讓云朵飄效果
這篇文章主要介紹了微信小程序開發(fā)之a(chǎn)nimation循環(huán)動(dòng)畫實(shí)現(xiàn)的讓云朵飄效果,結(jié)合實(shí)例形式分析了animation結(jié)合js時(shí)間函數(shù)實(shí)現(xiàn)循環(huán)動(dòng)畫效果的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-07-07
鼠標(biāo)拖動(dòng)改變DIV等網(wǎng)頁元素的大小的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄髽?biāo)拖動(dòng)改變DIV等網(wǎng)頁元素的大小的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07

