這篇文章主要介紹如何解決vue單頁面在微信下只能分享落地頁的問題,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
實(shí)際上關(guān)鍵詞叫 微信pushState只能分享落地頁 更貼切一點(diǎn)
應(yīng)用場(chǎng)景:
vue + vue-router
vue-router使用hash模式(history模式?jīng)]試過)
不使用微信的js-sdk(因?yàn)槲疫@個(gè)項(xiàng)目是可配置域名的商城,比較特殊,不能使用微信sdk)
這個(gè)方案并不是最優(yōu)秀的,會(huì)對(duì)性能造成一定的影響
HTML5 history.pushState
vue-router的內(nèi)部是通過 history.pushState 和 history.replaceState 實(shí)現(xiàn)的。但是iOS設(shè)備的微信瀏覽器不會(huì)去檢測(cè)它們的變化。但是我們可以通過更新 location.href 讓微信瀏覽器識(shí)別到當(dāng)前的url。
// vue-router/src/util/push-state.js export function pushState (url?: string, replace?: boolean) { saveScrollPosition() // try...catch the pushState call to get around Safari // DOM Exception 18 where it limits to 100 pushState calls const history = window.history try { if (replace) { history.replaceState({ key: _key }, '', url) } else { _key = genKey() history.pushState({ key: _key }, '', url) } } catch (e) { window.location[replace ? 'replace' : 'assign'](url) } } export function replaceState (url?: string) { pushState(url, true) }
解決方法
window.location.href = window.location.href
,這段代碼可以讓微信記錄當(dāng)前的url,且不會(huì)刷新頁面。可以在app.vue中 watch $route 在每次頁面更新的時(shí)候執(zhí)行一次。
// app.vue watch: { $route: { immediate: true, deep: true, handler(to) { // 微信瀏覽器判斷 const WECHAT_BROWSER = navigator.userAgent.toLowerCase().includes('micromessenger') // 解決iOS微信瀏覽器分享地址只能是落地頁的問題,這個(gè)操作是不會(huì)刷新頁面的,query參數(shù)改變也會(huì)執(zhí)行 if (WECHAT_BROWSER) { // eslint-disable-next-line window.location.href = window.location.href } } },
使用了上述方法可以解決這個(gè)問題,但是這會(huì)引出一個(gè)很奇葩的問題,在真機(jī)上進(jìn)入 http://192.168.1.5:8080 和 http://192.168.1.5:8080/#/ 這兩個(gè)頁面,其中有一個(gè)鏈接的bug依然存在。原因具體不清楚,經(jīng)過測(cè)試可以在入口文件(main.js)中在頁面還沒有展示內(nèi)容前刷新一次頁面,即可解決這個(gè)問題。
// main.js // 微信瀏覽器判斷 const WECHAT_BROWSER = navigator.userAgent.toLowerCase().includes('micromessenger') // 在url插入的search參數(shù),可以隨意,但是必須要 // 例:http://192.168.1.5:8080/?_wx_=1#/ const wxQuery = '_wx_=1' const isRepeatQuery = location.search.includes(wxQuery) if (WECHAT_BROWSER && !isRepeatQuery) { const unit = (location.search && location.search !== '?') ? '&' : '?' location.search += unit + wxQuery // 添加_wx_參數(shù),該操作會(huì)刷新頁面 }
上面的代碼之所以要在 hash 前面加一個(gè) ?_wx_=1 參數(shù),為了方便刷新頁面給一個(gè)標(biāo)志位判斷是否已刷新。參數(shù)的 key-value 隨意。
以上是“如何解決vue單頁面在微信下只能分享落地頁的問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
文章標(biāo)題:如何解決vue單頁面在微信下只能分享落地頁的問題-創(chuàng)新互聯(lián)
鏈接URL:http://www.2m8n56k.cn/article8/dodjip.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供域名注冊(cè)、網(wǎng)站策劃、品牌網(wǎng)站建設(shè)、商城網(wǎng)站、企業(yè)網(wǎng)站制作、網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:[email protected]。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容