這篇文章主要為大家展示了“vue做微信自定義分享的問(wèn)題有哪些”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“vue做微信自定義分享的問(wèn)題有哪些”這篇文章吧。
為芒康等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及芒康網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都做網(wǎng)站、網(wǎng)站設(shè)計(jì)、芒康網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!
問(wèn)題及解決方式
hash模式
在微信的官方文檔中,提到關(guān)于jsapi_ticket的簽名算法中,生成簽名的時(shí)候,當(dāng)前網(wǎng)頁(yè)的URL,不包含#及其后面的部分;而且自定義分享出去的鏈接,微信也會(huì)主動(dòng)往鏈接的后面拼接一些參數(shù),比如from之類的;這也就造成了一些問(wèn)題,比如要么簽名不正確,要么分析那個(gè)出去的鏈接,二次分享又回出問(wèn)題。
那么我這里的解決方式就是直接不用hash模式了,問(wèn)題又多,鏈接也不好看,直接使用mode: 'history'。
切換頁(yè)面簽名失效
這個(gè)在網(wǎng)上也有很多解決方案。由于我這里的項(xiàng)目里不需要細(xì)致到每個(gè)頁(yè)面都必須做自定義分享,只需要在觸發(fā)某些條件的時(shí)候觸發(fā)自定義分享,所以是這么做的。
在main.js文件中編寫自定義分享的函數(shù)邏輯;
// 微信自定義分享 Vue.prototype.wxShare = async function ({title , desc , link = window.location.href,imgUrl ,success}) { let that = this; // 當(dāng)前頁(yè)面地址 let url = window.location.href; // 調(diào)用后端服務(wù)獲取微信簽名內(nèi)容 let {data: wxCfg} = await that.ajax({api: that.api.wechatGetWxSdk, data: {url: url}}) if (!wx || !wxCfg) return; wx.config({ debug: false, appId: wxCfg.appId, timestamp: wxCfg.timestamp, nonceStr: wxCfg.nonceStr, signature: wxCfg.signature, jsApiList: ['updateAppMessageShareData', 'updateTimelineShareData', 'onMenuShareTimeline', 'onMenuShareAppMessage'] }); wx.ready(function () { wx.updateAppMessageShareData({ title: title, desc: desc, link: link, imgUrl: imgUrl, success: function () { success ? success() : '' } }) wx.updateTimelineShareData({ title: title, link: link, imgUrl: imgUrl, success: function () { success ? success() : '' } }) wx.onMenuShareTimeline({ title: title, link: link, imgUrl: imgUrl, success: function () { success ? success() : '' } }) wx.onMenuShareAppMessage({ title: title, desc: desc, link: link, imgUrl: imgUrl, success: function () { success ? success() : '' } }) }) wx.error(function (res) { that.$toast('請(qǐng)刷新當(dāng)前頁(yè)面后重試') }); }
在需要調(diào)用自定義分享的時(shí)候,就這樣調(diào)用
await this.wxShare({ title: '分享的標(biāo)題', desc: '分享的摘要', link: '分享出去的鏈接地址', imgUrl: '分享的封面圖', success: function(){ // 調(diào)用成功的回調(diào) } })
IOS路由跳轉(zhuǎn)之后依然簽名失效
上面的問(wèn)題解決之后,項(xiàng)目上線了,很多ios的用戶反饋個(gè)別頁(yè)面還是無(wú)法成功調(diào)用自定義分享,前期的解決方案很暴力...懟用戶,讓用戶刷新一下當(dāng)前頁(yè)面,誒不成想,就好了!
后來(lái)越來(lái)越多的反饋..沒(méi)辦法了,必須得想想轍解決一下...
就開(kāi)始找原因,發(fā)現(xiàn)android一點(diǎn)問(wèn)題沒(méi)有。
但是在ios上,無(wú)論路由跳轉(zhuǎn)多少次,復(fù)制出來(lái)的鏈接都是首次進(jìn)入的頁(yè)面的鏈接,于是改造一下上面的調(diào)用函數(shù)。
首先記錄首次進(jìn)入頁(yè)面的url
Vue.prototype.firstUrl = window.location.href;
然后在wxShare函數(shù)中加了一個(gè)判斷。
大致意思就是判斷當(dāng)前設(shè)備是不是ios,如果是,簽名用的url就使用firstUrl,如果不是,就使用window.location.href
然后上線,發(fā)現(xiàn)就沒(méi)有再出過(guò)問(wèn)題咯。
以上是“vue做微信自定義分享的問(wèn)題有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!