vue:微信單頁應(yīng)用多入口處理

趕時間的可以跳到最后看源代碼主慰,看不懂為什么這樣寫的回頭來重新看。

事情要從上個月說起该肴,公司接了個項目藐不,需要做一個微信端的應(yīng)用秦效,時間是兩個月拱雏。

由于之前做過一個簡單的微信商城铸抑,非常鄙視微信頁面跳轉(zhuǎn)時的拖沓,所以決定做單頁應(yīng)用蒲赂,使用vue框架來開發(fā)刁憋。

vue是個不錯的框架,加上源碼豐富若皱,一路做來還算順利尘颓,沒遇到什么特別難的地方。

滿以為下周可以順利上線了互广,直到要放到微信端的時候出問題了卧土。

客戶需要在公眾號做一個這樣的菜單:

QQ圖片20170726001921.png

菜單的入口鏈接到單頁應(yīng)用的不同頁面尤莺。

而單頁應(yīng)用的內(nèi)部地址是通過#后面的內(nèi)容指引router跳轉(zhuǎn)的:
例如跳轉(zhuǎn)到關(guān)于我們的頁面
http://xxxx.xxx.com/#/about?appid=1&cpid=1

其中appid和cpid是必須的參數(shù),傳給單頁應(yīng)用后會賦值給vuex作為全局變量扫皱。

但是代碼打包發(fā)布之后捷绑,通過這個地址死活進(jìn)不去該進(jìn)的頁面氢妈,一律進(jìn)到根目錄下首量。據(jù)后端人員反映进苍,經(jīng)過微信瀏覽器傳到服務(wù)器的頁面地址鸭叙,#號連同后面的參數(shù)一并丟失沈贝。

不是吧


Paste_Image.png

這是個重大bug,如果下周在上線時客戶那邊不能忽悠過去,他們一定不肯支付尾款嗡善,公司可能會炒我魷魚学歧,老婆發(fā)現(xiàn)下個月工資卡沒錢到賬,會把家里電腦里的cpu拆了讓我跪袁铐,我受苦不要緊横浑,可憐了cpu呀伪嫁!

遂百度之。

十分鐘之后帝洪,我放棄了脚猾。找不到合適的解決方案

也有提出類似問題的

http://www.cnblogs.com/mingxinice/p/mingxin.html

但也沒有好的解決方案

還看到一個類似的但是看了半天他也不知道自己怎么解決的。
http://www.reibang.com/p/a1a31f9da272

或者是可以解決砰奕,將router模式改為history,但需要后端做一大堆事的提鸟,可這不就違背了前后端分離的真諦了嗎?

哎胸哥,為了平復(fù)我忐忑的心赡鲜,我心中不禁念起了大悲咒:“南無·喝啰怛那·哆啰夜耶...”

...在電光火石之間,我的心中閃過了一個念頭嘲更,得到了一個解決辦法。

這個辦法也許隱世的前端高手也正在使用篓冲,但除了這里纹因,你很難百度到琳拨,如果對你有幫助,請打賞一下惊畏。

如上所述密任,微信跳轉(zhuǎn)時颜启,瀏覽器會把#后面的hash值給搞掉,據(jù)說在ios中還會在前面加點東西浪讳。但是在#之前加的get參數(shù)是不會丟失的缰盏。

那么我們?yōu)槭裁床荒馨褏?shù)前移呢?像這樣:

http://xxxx.xxx.com/?appid=1&cpid=1

頁面跳轉(zhuǎn)怎么辦淹遵?我可以加一個page參數(shù)呀

http://xxxx.xxx.com/?appid=1&cpid=1&page=/about

這樣寫就完全丟棄了#

然后我們通過一個js方法獲取鏈接的參數(shù)

getQueryString(name) {
        var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
        var r = window.location.search.substr(1).match(reg);
        if (r != null) return unescape(r[2]);
        return null;
    }

我把這個方法放到了一個文件中口猜,并作為全局對象引入,當(dāng)然透揣,你也可以直接放到main.js里

在main.js里,router.beforeEach這個鉤子之前济炎,將獲得的參數(shù)賦值給一個全局對象。

global.browserQuery = {
    appid: getQueryString('appid'),
    cpid: getQueryString('cpid'),
    page: getQueryString('page')
}

在router.beforeEach的鉤子里這樣寫:

router.beforeEach(({ meta, path, query }, from, next) => {
    if (browserQuery.appid && browserQuery.cpid) {
        store.commit('appid', browserQuery.appid);
        store.commit('cpid', browserQuery.cpid);
        let p=browserQuery.page;
        browserQuery={};
        return next(p);
    }
    ///其它代碼
})

解釋一下须尚,如果browserQuery不是空對象,說明是從外面的鏈接點擊首次進(jìn)入的侍咱,這時候?qū)⑺枰膮?shù)寫進(jìn)store中耐床,剩下的page是要跳轉(zhuǎn)到的路由,賦值給p變量楔脯,然后清空browserQuery對象撩轰,使下次跳轉(zhuǎn)不再進(jìn)入這個條件代碼段,然后用return next(p)跳轉(zhuǎn)到該去的頁面。

可是一測試钧敞,問題又來了。在本地測試(沒發(fā)布到微信)

鏈接:http://xxxx.xxx.com/?appid=1&cpid=1&page=/about

還是跳轉(zhuǎn)到根目錄麸粮,但后面加#/卻能正確跳轉(zhuǎn)到about頁面

http://xxxx.xxx.com/?appid=1&cpid=1&page=/about#/

為什么呢溉苛?唯一的解釋是,沒有hash值弄诲,router沒有準(zhǔn)備好愚战,所以默認(rèn)跳轉(zhuǎn)到根目錄。但#/會被微信丟掉呀齐遵,加了也沒用寂玲,這不矛盾嗎?

能不能跳轉(zhuǎn)兩次梗摇?先跳到#/,這時router加載了拓哟,再跳轉(zhuǎn)到#/about

所以我寫成這樣

router.beforeEach(({ meta, path, query }, from, next) => {
    if (browserQuery.appid && browserQuery.cpid) {
        store.commit('appid', browserQuery.appid);
        store.commit('cpid', browserQuery.cpid);
        delete browserQuery.appid;
        return next('/');
    }else if(browserQuery.page){
       let p=browserQuery.page;
       browserQuery={};
       return next(p);
    }
    ///其它代碼
})

頁面進(jìn)來后,刪掉appid,并讓它先跳轉(zhuǎn)到根目錄'/'伶授,這時appid已經(jīng)不在断序,所以不會進(jìn)入條件一,而會進(jìn)入else,因為page還在糜烹,清空browserQuery,并跳轉(zhuǎn)到該去的頁面about,因為跳轉(zhuǎn)前為根目錄'/',hash值已在违诗,應(yīng)當(dāng)不會出現(xiàn)上述問題。

但一測試疮蹦,還是不行诸迟。

我猜想這個router.beforeEach鉤子是不支持這樣瞬間跳轉(zhuǎn)兩次的。也就是在return next('/') 之后愕乎,不會立即執(zhí)行下一個beforeEach的鉤子阵苇。

能不能放在router.afterEach里呢?試試妆毕!

router.beforeEach(({ meta, path, query }, from, next) => {
    if (browserQuery.appid && browserQuery.cpid) {
        store.commit('appid', browserQuery.appid);
        store.commit('cpid', browserQuery.cpid);
        delete browserQuery.appid;
        return next('/');
    }
      ///其它代碼
})
router.afterEach(route => {
        if (browserQuery.page) {
            let p = browserQuery.page;
            browserQuery = {};
            router.push(p);//因為沒有next對象慎玖,直接調(diào)用router跳轉(zhuǎn)
        }
    })

當(dāng)router導(dǎo)航到根目錄'/'之后,馬上跳轉(zhuǎn)到about頁面笛粘,這時雖然是路由成功趁怔,但根目錄頁面還沒有渲染,其實看不出有什么差別薪前。成功了润努。

對!就這么解決了困擾單頁的多入口問題了示括。

如果你要將其中一個頁面分享出去铺浇,可以這樣組織鏈接,例如
http://xxxx.xxx.com/?appid=1&cpid=1&page=/detail/1

當(dāng)其他人點擊鏈接后垛膝,會被導(dǎo)航到
http://xxxx.xxx.com/#/detail/1頁面

從此你可以告別#的困擾鳍侣,單頁應(yīng)用從此不再受微信的歧視丁稀。

吸了一口維他奶,感嘆啊倚聚。業(yè)界難題被我輕而易舉解決了线衫,如果我不當(dāng)程序員,真實IT界的損失呀惑折。嘻嘻嘻嘻(笑)

全部代碼如下:

getQueryString(name) {
        var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
        var r = window.location.search.substr(1).match(reg);
        if (r != null) return unescape(r[2]);
        return null;
    }
global.browserQuery = {
    appid: getQueryString('appid'),
    cpid: getQueryString('cpid'),
    page: getQueryString('page')
}
router.beforeEach(({ meta, path, query }, from, next) => {
    if (browserQuery.appid && browserQuery.cpid) {
        store.commit('appid', browserQuery.appid);
        store.commit('cpid', browserQuery.cpid);
        delete browserQuery.appid;
        return next('/');
    }
      ///其它代碼
})
router.afterEach(route => {
        if (browserQuery.page) {
            let p = browserQuery.page;
            browserQuery = {};
            router.push(p);//因為沒有next對象授账,直接調(diào)用router跳轉(zhuǎn)
        }
    })
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市惨驶,隨后出現(xiàn)的幾起案子白热,更是在濱河造成了極大的恐慌,老刑警劉巖粗卜,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件屋确,死亡現(xiàn)場離奇詭異,居然都是意外死亡休建,警方通過查閱死者的電腦和手機(jī)乍恐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來测砂,“玉大人茵烈,你說我怎么就攤上這事∑鲂” “怎么了呜投?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長存璃。 經(jīng)常有香客問我仑荐,道長,這世上最難降的妖魔是什么纵东? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任粘招,我火速辦了婚禮,結(jié)果婚禮上偎球,老公的妹妹穿的比我還像新娘洒扎。我一直安慰自己,他們只是感情好衰絮,可當(dāng)我...
    茶點故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布袍冷。 她就那樣靜靜地躺著,像睡著了一般猫牡。 火紅的嫁衣襯著肌膚如雪胡诗。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天,我揣著相機(jī)與錄音煌恢,去河邊找鬼骇陈。 笑死,一個胖子當(dāng)著我的面吹牛瑰抵,可吹牛的內(nèi)容都是我干的缩歪。 我是一名探鬼主播,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼谍憔,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了主籍?” 一聲冷哼從身側(cè)響起习贫,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎千元,沒想到半個月后苫昌,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡幸海,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年祟身,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片物独。...
    茶點故事閱讀 38,018評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡袜硫,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出挡篓,到底是詐尸還是另有隱情婉陷,我是刑警寧澤,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布官研,位于F島的核電站秽澳,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏戏羽。R本人自食惡果不足惜担神,卻給世界環(huán)境...
    茶點故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望始花。 院中可真熱鬧妄讯,春花似錦、人聲如沸衙荐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽忧吟。三九已至砌函,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背讹俊。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工垦沉, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人仍劈。 一個月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓厕倍,卻偏偏與公主長得像,于是被迫代替她去往敵國和親贩疙。 傳聞我的和親對象是個殘疾皇子讹弯,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,762評論 2 345

推薦閱讀更多精彩內(nèi)容