vue實(shí)現(xiàn)微信分享功能
本文實(shí)例為大家分享了vue實(shí)現(xiàn)微信分享功能的具體代碼,供大家參考,具體內(nèi)容如下
1.引入微信js
<script type="text/javascript" src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script>
2.從后臺獲取簽名并分享
fenxiangFun(){//詳情分享 var that = this; this.$http({ url:this.changeData() + '/member/weChatShare', method: "post", params: { url : window.location.href.split('#')[0] } }).then(function(res){ // console.log(res) wx.config({ //debug: true, // 開啟調(diào)試模式,調(diào)用的所有api的返回值會在客戶端alert出來,若要查看傳入的參數(shù),可以在pc端打開,參數(shù)信息會通過log打出,僅在pc端時才會打印。 appId: res.data.appId, // 必填,公眾號的唯一標(biāo)識 timestamp: res.data.timestamp, // 必填,生成簽名的時間戳 nonceStr: res.data.nonceStr, // 必填,生成簽名的隨機(jī)串 signature: res.data.signature,// 必填,簽名 jsApiList: ["onMenuShareAppMessage","onMenuShareTimeline"] // 必填,需要使用的JS接口列表 }); wx.ready(function(){ // config信息驗(yàn)證后會執(zhí)行ready方法,所有接口調(diào)用都必須在config接口獲得結(jié)果之后,config是一個客戶端的異步操作,所以如果需要在頁面加載時就調(diào)用相關(guān)接口,則須把相關(guān)接口放在ready函數(shù)中調(diào)用來確保正確執(zhí)行。對于用戶觸發(fā)時才調(diào)用的接口,則可以直接調(diào)用,不需要放在ready函數(shù)中。 //分享給朋友 wx.onMenuShareAppMessage({ title: that.projectDetail.project_name, // 分享標(biāo)題 desc: '賣鋪寶', // 分享描述 link: window.location.href.split('#')[0], // 分享鏈接,該鏈接域名或路徑必須與當(dāng)前頁面對應(yīng)的公眾號JS安全域名一致 imgUrl: that.projectPic[0], // 分享圖標(biāo) type: '', // 分享類型,music、video或link,不填默認(rèn)為link dataUrl: '', // 如果type是music或video,則要提供數(shù)據(jù)鏈接,默認(rèn)為空 success: function () { // 用戶點(diǎn)擊了分享后執(zhí)行的回調(diào)函數(shù) } }); //分享到朋友圈 wx.onMenuShareTimeline({ title: that.projectDetail.project_name, // 分享標(biāo)題 link: window.location.href.split('#')[0], // 分享鏈接,該鏈接域名或路徑必須與當(dāng)前頁面對應(yīng)的公眾號JS安全域名一致 imgUrl: that.projectPic[0], // 分享圖標(biāo) success: function () { // 用戶點(diǎn)擊了分享后執(zhí)行的回調(diào)函數(shù) } }); }); wx.error(function(res){ // config信息驗(yàn)證失敗會執(zhí)行error函數(shù),如簽名過期導(dǎo)致驗(yàn)證失敗,具體錯誤信息可以打開config的debug模式查看,也可以在返回的res參數(shù)中查看,對于SPA可以在這里更新簽名。 }); }.bind(this)).catch(function(err){ console.log("商店詳情頁面錯誤:",err) }); },
3.ios兼容性問題
beforeRouteEnter (to, from, next) { var u = navigator.userAgent; var isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); //ios終端 // XXX: 修復(fù)iOS版微信HTML5 History兼容性問題 if (isiOS && to.path !== location.pathname) { // 此處不可使用location.replace location.assign(to.fullPath) } else { next() } },
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- VueJs單頁應(yīng)用實(shí)現(xiàn)微信網(wǎng)頁授權(quán)及微信分享功能示例
- vue實(shí)現(xiàn)微信分享朋友圈,發(fā)送朋友的示例講解
- Vue單頁式應(yīng)用(Hash模式下)實(shí)現(xiàn)微信分享的實(shí)例
- vue微信分享 vue實(shí)現(xiàn)當(dāng)前頁面分享其他頁面
- vue微信分享出來的鏈接點(diǎn)開是首頁問題的解決方法
- Vue項(xiàng)目全局配置微信分享思路詳解
- vue-cli構(gòu)建項(xiàng)目下使用微信分享功能
- vue項(xiàng)目中實(shí)現(xiàn)的微信分享功能示例
- vue-router history模式下的微信分享小結(jié)
- vue微信分享插件使用方法詳解
相關(guān)文章
vue directive全局自定義指令實(shí)現(xiàn)按鈕級別權(quán)限控制的操作方法
這篇文章主要介紹了vue directive全局自定義指令實(shí)現(xiàn)按鈕級別權(quán)限控制,本文結(jié)合實(shí)例代碼對基本概念做了詳細(xì)講解,需要的朋友可以參考下2023-02-02vue-cli如何快速構(gòu)建vue項(xiàng)目
本篇文章主要介紹了vue-cli如何快速構(gòu)建vue項(xiàng)目,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04vue如何實(shí)現(xiàn)多組關(guān)鍵詞對應(yīng)高亮顯示
這篇文章主要介紹了vue如何實(shí)現(xiàn)多組關(guān)鍵詞對應(yīng)高亮顯示問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10vue cli構(gòu)建的項(xiàng)目中請求代理與項(xiàng)目打包問題
這篇文章主要介紹了vue cli構(gòu)建的項(xiàng)目中請求代理與項(xiàng)目打包問題,需要的朋友可以參考下2018-02-02vue+jsplumb實(shí)現(xiàn)工作流程圖的項(xiàng)目實(shí)踐
本文主要介紹了vue+jsplumb實(shí)現(xiàn)工作流程圖的項(xiàng)目實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04