vue2.0 如何在hash模式下實(shí)現(xiàn)微信分享
最近又把vue的demo拿出來(lái)整理下,正好要做“微信分享”功能,于是遇到新的問(wèn)題;
由于hash模式下,帶有“#”,導(dǎo)致微信分享的簽證無(wú)效;當(dāng)改成history的模式后,分享ok;
但是問(wèn)題來(lái)了,history模式下相當(dāng)、、:
- 刷新頁(yè)面,頁(yè)面報(bào)錯(cuò)404;這不是扯犢子嗎?【不過(guò)這個(gè)問(wèn)題,可以在后臺(tái)解決,這里就不說(shuō)了】
- assets下的img文件,引入路徑失??;
對(duì)于上面的問(wèn)題,我是直接不能忍啊,所以history模式是肯定不行的;我決定依舊用hash模式;history模式萬(wàn)萬(wàn)要不得
那么問(wèn)題來(lái)了:怎么在hash模式下實(shí)現(xiàn)微信分享?
其實(shí)微信分享失敗的問(wèn)題,最重要的一步就是解決“#”的問(wèn)題;
一般的頁(yè)面,我們獲取當(dāng)前的url是醬紫操作的
let params = '¶ms=' + JSON.stringify({url: window.location.href});
SPA頁(yè)面,我們需要做點(diǎn)小調(diào)整,調(diào)整的目的是讓“#”say goodbye
let params = '¶ms=' + JSON.stringify({url: encodeURIComponent(window.location.href.split('#')[0])});
這樣修改后,簽名的url中沒(méi)帶“#”,這樣就ok了,下面貼上完成的代碼
<script> // 微信分享 import configModel from "../models/config.model"; import elementService from "../services/element.service"; class ShareService{ wxShare(succCb, cancelCb, errorCb){ let baseUrl = 'http://q.letwx.com/api/jsapi?action=jscfg'; let samekey = '&uid=' + configModel.uid + '&wxapiopenid=' + configModel.apiopenid + '&wxapitoken=' + configModel.apitoken + '&debug=nf'; let params = '¶ms=' + JSON.stringify({url: encodeURIComponent(window.location.href.split('#')[0])}); // 這里是關(guān)鍵 let url = baseUrl + params + samekey; $.post(url, data => { elementService.loadingHide(); console.log(data); switch (data.error) { case 0: this.wxConfig(data.cfg, configModel.shareInfo, succCb, cancelCb, errorCb); break; default: elementService.message(data.error_msg, 'error'); break; } }, 'json'); } wxConfig(wxconfig, share, succCb, cancelCb, errorCb){ wx.config({ debug: false, appId: wxconfig.appId, timestamp: wxconfig.timestamp, nonceStr: wxconfig.nonceStr, signature: wxconfig.signature, jsApiList: [ 'onMenuShareTimeline', 'onMenuShareAppMessage', 'onMenuShareQQ', 'onMenuShareWeibo' ] }); wx.ready(function() { wx.onMenuShareAppMessage({ //朋友 title: share.title, desc: share.desc, link: share.link, imgUrl: share.imgUrl, success: function() { succCb && succCb(); }, cancel: function() { cancelCb && cancelCb(); } }); wx.onMenuShareTimeline({ //朋友圈 title: share.desc, link: share.link, imgUrl: share.imgUrl, success: function() { succCb && succCb(); }, cancel: function() { cancelCb && cancelCb(); } }); wx.onMenuShareQQ({ //QQ title: share.title, desc: share.desc, link: share.link, imgUrl: share.imgUrl, success: function() { succCb && succCb(); }, cancel: function() { cancelCb && cancelCb(); } }); wx.onMenuShareWeibo({ //QQ title: share.title, desc: share.desc, link: share.link, imgUrl: share.imgUrl, success: function() { succCb && succCb(); }, cancel: function() { cancelCb && cancelCb(); } }); }); wx.error(function(res) { console.log(res); errorCb && errorCb(JSON.stringify(res)); }); } } let shareSerivice = new ShareService(); export default shareSerivice; </script>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
elementUI自定義上傳文件功能實(shí)現(xiàn)(前端后端超詳細(xì)過(guò)程)
自定義上傳思路很簡(jiǎn)單,下面這篇文章主要給大家介紹了關(guān)于elementUI自定義上傳文件功能實(shí)現(xiàn)(前端后端超詳細(xì)過(guò)程)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11vue實(shí)現(xiàn)幾秒后跳轉(zhuǎn)新頁(yè)面代碼
這篇文章主要介紹了vue實(shí)現(xiàn)幾秒后跳轉(zhuǎn)新頁(yè)面代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09vue中項(xiàng)目頁(yè)面空白但不報(bào)錯(cuò)產(chǎn)生的原因及分析
這篇文章主要介紹了vue中項(xiàng)目頁(yè)面空白但不報(bào)錯(cuò)產(chǎn)生的原因及分析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05Vue打包后訪問(wèn)靜態(tài)資源路徑問(wèn)題
在本篇文章里小編給各位整理的是關(guān)于Vue打包后訪問(wèn)靜態(tài)資源路徑問(wèn)題相關(guān)知識(shí)點(diǎn),需要的朋友們學(xué)習(xí)下。2019-11-11使用 vue.js 構(gòu)建大型單頁(yè)應(yīng)用
本文給大家詳細(xì)介紹了如何使用使用 vue.js腳手架工具vue-cli構(gòu)建大型單頁(yè)應(yīng)用的方法,非常的實(shí)用,有需要的小伙伴可以參考下2018-02-02vue項(xiàng)目設(shè)置活性字體過(guò)程(自適應(yīng)字體大小)
這篇文章主要介紹了vue項(xiàng)目設(shè)置活性字體過(guò)程(自適應(yīng)字體大小),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09VUE之關(guān)于store狀態(tài)管理核心解析
這篇文章主要介紹了VUE之關(guān)于store狀態(tài)管理核心解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06