国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

記錄vue做微信自定義分享的一些問題

2019-11-19 09:22:20
字體:
供稿:網(wǎng)友

前言

眾所周知,在使用vue做項(xiàng)目的時(shí)候,微信自定義分享一直是一個(gè)坑,只是ios上坑明顯的多。

然后每次遇到問題都要度娘很久。

奇怪的是貌似和很多人遇到的問題一樣,但是他們寫的解決方案都沒辦法直接解決我遇到的問題。

這里就記錄一下遇到過的一些坑,和解決方式。

目前項(xiàng)目里面,安卓和ios上面的自定義分享已經(jīng)沒有什么問題了。

問題及解決方式

hash模式

在微信的官方文檔中,提到關(guān)于jsapi_ticket的簽名算法中,生成簽名的時(shí)候,當(dāng)前網(wǎng)頁的URL,不包含#及其后面的部分;而且自定義分享出去的鏈接,微信也會(huì)主動(dòng)往鏈接的后面拼接一些參數(shù),比如from之類的;這也就造成了一些問題,比如要么簽名不正確,要么分析那個(gè)出去的鏈接,二次分享又回出問題。

那么我這里的解決方式就是直接不用hash模式了,問題又多,鏈接也不好看,直接使用mode: 'history'。

切換頁面簽名失效

這個(gè)在網(wǎng)上也有很多解決方案。由于我這里的項(xiàng)目里不需要細(xì)致到每個(gè)頁面都必須做自定義分享,只需要在觸發(fā)某些條件的時(shí)候觸發(fā)自定義分享,所以是這么做的。

在main.js文件中編寫自定義分享的函數(shù)邏輯;

// 微信自定義分享Vue.prototype.wxShare = async function ({title , desc , link = window.location.href,imgUrl ,success}) {  let that = this;  // 當(dāng)前頁面地址  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)前頁面后重試')  });}

在需要調(diào)用自定義分享的時(shí)候,就這樣調(diào)用

await this.wxShare({  title: '分享的標(biāo)題',   desc: '分享的摘要',  link: '分享出去的鏈接地址',  imgUrl: '分享的封面圖',  success: function(){    // 調(diào)用成功的回調(diào)  }})

IOS路由跳轉(zhuǎn)之后依然簽名失效

上面的問題解決之后,項(xiàng)目上線了,很多ios的用戶反饋個(gè)別頁面還是無法成功調(diào)用自定義分享,前期的解決方案很暴力...懟用戶,讓用戶刷新一下當(dāng)前頁面,誒不成想,就好了!

后來越來越多的反饋..沒辦法了,必須得想想轍解決一下...

就開始找原因,發(fā)現(xiàn)android一點(diǎn)問題沒有。

但是在ios上,無論路由跳轉(zhuǎn)多少次,復(fù)制出來的鏈接都是首次進(jìn)入的頁面的鏈接,于是改造一下上面的調(diào)用函數(shù)。
首先記錄首次進(jìn)入頁面的url

Vue.prototype.firstUrl = window.location.href;

然后在wxShare函數(shù)中加了一個(gè)判斷。

大致意思就是判斷當(dāng)前設(shè)備是不是ios,如果是,簽名用的url就使用firstUrl,如果不是,就使用window.location.href

然后上線,發(fā)現(xiàn)就沒有再出過問題咯。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 延安市| 瑞昌市| 丹棱县| 景东| 依安县| 沁阳市| 海口市| 罗江县| 弋阳县| 惠安县| 会泽县| 邳州市| 凭祥市| 龙胜| 榆中县| 深水埗区| 县级市| 鄂尔多斯市| 铜陵市| 图们市| 鄄城县| 台州市| 石林| 青铜峡市| 江孜县| 余江县| 丰顺县| 兴安县| 西安市| 高邑县| 磐石市| 三明市| 平顺县| 和政县| 襄城县| 体育| 永兴县| 会同县| 政和县| 贵阳市| 柘城县|