前端路由

2019/4/1
通過記錄url的變化來記錄ajax的變化(ajax的標(biāo)簽化),從而實現(xiàn)前端路由。
前端路由存在缺陷:使用瀏覽器的前進坯癣,后退鍵時會重新發(fā)送請求,來獲取數(shù)據(jù)乖菱,沒有合理地利用緩存坡锡。

  • 前端路由實現(xiàn)
    1.1
    基于location.hash實現(xiàn)
    location.hash的值就是URL中#后面的內(nèi)容
    如:
https://www.baidu.com#user

location.hash = user;
1.2 hash的特性

    • URL中hash值只是客戶端的一種狀態(tài),也就是說當(dāng)向服務(wù)器端發(fā)出請求時窒所,hash部分不會被發(fā)送鹉勒。
    • hash值的改變,都會在瀏覽器的訪問歷史中增加一個記錄吵取。因此我們能通過瀏覽器的回退禽额、前進按鈕控制hash的切換。
    • 使用hashchange事件來監(jiān)聽hash的變化。
      1.3 觸發(fā)hash值改變的方法
      1.3.1 使用a標(biāo)簽
      <a href="#user"></a>
      1.3.2使用loaction.hash進行賦值
      loaction.hash = "#user"

2.1 基于History API
history.pushState()和history.repalceState()
都會操作瀏覽器的歷史記錄脯倒,而不會引起頁面的刷新实辑,不同在于pushState會增加一條新的歷史記錄,而replaceState則會替換當(dāng)前的歷史記錄藻丢。
2.2參數(shù)問題

    • 狀態(tài)對象(state object) — 一個JavaScript對象剪撬,與用pushState()方法創(chuàng)建的新歷史記錄條目關(guān)聯(lián)。無論何時用戶導(dǎo)航到新創(chuàng)建的狀態(tài)悠反,popstate事件都會被觸發(fā)残黑,并且事件對象的state屬性都包含歷史記錄條目的狀態(tài)對象的拷貝。
    • 標(biāo)題(title) — FireFox瀏覽器目前會忽略該參數(shù)斋否,考慮到未來可能會對該方法進行修改梨水,傳一個空字符串會比較安全∫鸪簦或者疫诽,你也可以傳入一個簡短的標(biāo)題,標(biāo)明將要進入的狀態(tài)旦委。
    • 地址(URL) — 新的歷史記錄條目的地址奇徒。瀏覽器不會在調(diào)用pushState()方法后加載該地址,但之后缨硝,可能會試圖加載逼龟,例如用戶重啟瀏覽器。新的URL不一定是絕對路徑追葡;如果是相對路徑,它將以當(dāng)前URL為基準(zhǔn)奕短;傳入的URL與當(dāng)前URL應(yīng)該是同源的宜肉,否則,pushState()會拋出異常翎碑。該參數(shù)是可選的谬返;不指定的話則為文檔當(dāng)前URL。
      ps:暫時性理解日杈,后續(xù)深入理解后再更新.預(yù)計三天內(nèi)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末遣铝,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子莉擒,更是在濱河造成了極大的恐慌酿炸,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件涨冀,死亡現(xiàn)場離奇詭異填硕,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進店門扁眯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來壮莹,“玉大人,你說我怎么就攤上這事姻檀∶” “怎么了?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵绣版,是天一觀的道長胶台。 經(jīng)常有香客問我,道長僵娃,這世上最難降的妖魔是什么概作? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮默怨,結(jié)果婚禮上讯榕,老公的妹妹穿的比我還像新娘。我一直安慰自己匙睹,他們只是感情好愚屁,可當(dāng)我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著痕檬,像睡著了一般霎槐。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上梦谜,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天丘跌,我揣著相機與錄音,去河邊找鬼唁桩。 笑死闭树,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的荒澡。 我是一名探鬼主播报辱,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼单山!你這毒婦竟也來了乐埠?” 一聲冷哼從身側(cè)響起媒吗,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后徒像,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體毡庆,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡溯革,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年节榜,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡一睁,死狀恐怖钻弄,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情者吁,我是刑警寧澤窘俺,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站复凳,受9級特大地震影響瘤泪,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜育八,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一对途、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧髓棋,春花似錦实檀、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至签则,卻和暖如春须床,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背渐裂。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工豺旬, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人柒凉。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓哈垢,卻偏偏與公主長得像,于是被迫代替她去往敵國和親扛拨。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,614評論 2 353

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