vue微信分享的實(shí)現(xiàn)(在當(dāng)前頁面分享其他頁面)
首先以分享給朋友為例
1、先看官方文檔
wx.onMenuShareAppMessage({
title: '', // 分享標(biāo)題
desc: '', // 分享描述
link: '', // 分享鏈接,該鏈接域名或路徑必須與當(dāng)前頁面對(duì)應(yīng)的公眾號(hào)JS安全域名一致
imgUrl: '', // 分享圖標(biāo)
type: '', // 分享類型,music、video或link,不填默認(rèn)為link
dataUrl: '', // 如果type是music或video,則要提供數(shù)據(jù)鏈接,默認(rèn)為空
success: function () {
// 用戶確認(rèn)分享后執(zhí)行的回調(diào)函數(shù)
},
cancel: function () {
// 用戶取消分享后執(zhí)行的回調(diào)函數(shù)
}
});
2、vue分享踩的坑
* 1、微信分享中獲取動(dòng)態(tài)的url
* 2、 微信二次分享自動(dòng)添加的參數(shù) form=singlemessage
* 3、vue中各個(gè)頁面都可以調(diào)用分享
3、直接代碼分析
為了保證每個(gè)頁面都可以調(diào)起微信分享,需要在vue根組件中,添加 watch監(jiān)聽
代碼
watch: {
// 監(jiān)聽 $route 變化調(diào)用分享鏈接
"$route"(to, from) {
let currentRouter = this.$router.currentRoute.fullPath; //
if(currentRouter.indexOf('userShare') == -1){ //如果不是userShare分享頁面,則分享另外一個(gè)接口
this.shareOut();
}else{
this.shareOutTwo(); //當(dāng)前頁面是userShare頁面時(shí)分享調(diào)用另外一個(gè)接口
}
}
},
4、shareOut()函數(shù)
let signStr = ''; //sha1加密字符串
let timestamp = 1473254558; //時(shí)間戳
let nonceStr = 'shupao';
var obj = {
title:"", //標(biāo)題
desc:"文字描述", //描述
link:"http://www.XXXXXX.com/wx/pub/sr/simpleRegister.do",
imgUrl:"http://XXXXXXXXX.com/picactive.jpg"
};
this.$ydkAjax({
SENTYPE: "GET",
url: this.$domain + '/wx/pub/common/getJsApiTicket.json', //自己服務(wù)器獲取jsapi_ticket接口
params: null,
successFc: (response) => {
//拼接sha1加密字符串
signStr = 'jsapi_ticket=' + response.data.data + '&noncestr=' + nonceStr + '×tamp=' + timestamp + '&url=' + window.location.href;
var signature = SHA1(signStr);
wx.config({
debug: false,
appId: "wx6957b3a945a05e90", //appId
timestamp: timestamp, //時(shí)間戳
nonceStr: nonceStr, //加密需要字符串(自己定義的)
signature: signature, //sha1加密后字符串
jsApiList: [ 'onMenuShareTimeline', 'onMenuShareAppMessage']
});
wx.ready(function () {
//分享到朋友圈"
wx.onMenuShareTimeline({
title: obj.title,
link: obj.link, // 分享鏈接
imgUrl: obj.imgUrl, // 分享圖標(biāo)
success: function () {
// console.log('分享到朋友圈成功')
},
cancel: function () {
// console.log('分享到朋友圈失敗')
}
});
//分享給朋友
wx.onMenuShareAppMessage({
title: obj.title, // 分享標(biāo)題
desc: obj.desc, // 分享描述
link: obj.link, // 分享鏈接
imgUrl: obj.imgUrl, // 分享圖標(biāo)
success: function () {
// console.log('分享到朋友成功')
},
cancel: function () {
// console.log('分享到朋友失敗')
}
});
})
},
isLayer: false
})
5、需要注意的事
*1、url是直接通過 window.location.href 獲取的,不是使用 window.location.href.split(“#”)[0]來獲取, 因?yàn)槲业膙ue項(xiàng)目是通過hash模式來進(jìn)行路由跳轉(zhuǎn)的 , 直接使用 window.location.href.split(“#”)[0]會(huì)導(dǎo)致簽名失敗
//拼接sha1加密字符串 signStr = 'jsapi_ticket=' + response.data.data + '&noncestr=' + nonceStr + '×tamp=' + timestamp + '&url=' + window.location.href
*2、而且我們要在當(dāng)前頁面分享出去之后 , 其他用戶打開之后 不是當(dāng)前分享出去的頁面 ,這就需要 調(diào)整 shareOut()函數(shù)中 obj對(duì)象中的 link參數(shù)為其他頁面鏈接
6、link參數(shù)
上述 5 問題中的加密字符串匯總的 url 和 分享對(duì)象中 link中的頁面鏈接可以不用保持一樣,因?yàn)楸緛砭褪且诋?dāng)前頁面分享出去其他頁面的鏈接。網(wǎng)上我看到有人說這兩個(gè)必須要保持一樣,其實(shí)沒有必要, 除非你只是簡(jiǎn)單的在vue項(xiàng)目中的其中一個(gè)頁面做分享 , 然后只分享當(dāng)前頁面才需要讓二者保持一致性。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
一文詳解vue-router中的導(dǎo)航守衛(wèi)
vue-router提供的導(dǎo)航守衛(wèi)主要用來通過跳轉(zhuǎn)或取消的方式守衛(wèi)導(dǎo)航,在 vue-router 中,導(dǎo)航守衛(wèi)是一種非常重要的功能,所以本文將詳細(xì)講解一下vue-router中的導(dǎo)航守衛(wèi),感興趣的同學(xué)跟著小編一起來看看吧2023-07-07
解決axios發(fā)送post請(qǐng)求返回400狀態(tài)碼的問題
今天小編就為大家分享一篇解決axios發(fā)送post請(qǐng)求返回400狀態(tài)碼的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08
Vue3實(shí)現(xiàn)粒子動(dòng)態(tài)背景的示例詳解
這篇文章主要為大家詳細(xì)介紹了如何利用Vue3實(shí)現(xiàn)粒子動(dòng)態(tài)背景,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以跟隨小編一起了解一下2023-11-11
詳解從新建vue項(xiàng)目到引入組件Element的方法
本篇文章主要介紹了詳解從新建vue項(xiàng)目到引入組件Element的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08
Vue router-view和router-link的實(shí)現(xiàn)原理
這篇文章主要介紹了Vue router-view和router-link的實(shí)現(xiàn)原理,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03

