前端路由

路由是什么

路由是用来分发请求

路由模式

hash模式,history模式,memory模式

1.hash模式

任何情况都能使用,但seo不友好(服务器无法获取hash)
我们创建一个id为app的div,然后创建5个div,一开始让它们display:none

<!DOCTYPE html>
<html>

<head>
    <title>Parcel Sandbox</title>
    <meta charset="UTF-8" />
</head>

<body>
    <div id="app"></div>
    <div id="div1" style="display:none;">1</div>
    <div id="div2" style="display:none;">2</div>
    <div id="div3" style="display:none;">3</div>
    <div id="div4" style="display:none;">4</div>
    <div id="div5" style="display:none;">5</div>
    <script src="src/index.js">
    </script>
</body>

</html>

我们通过不同的hash,将不同的元素挂在到app上

const number = window.location.hash.substr(1);
const div = document.querySelector(`#div${number}`);
const app = document.querySelector("#app");
div.style.display = "block";
app.appendChild(div);
image.png
image.png
 <a href="#1">to_1</a>
 <a href="#2">to_2</a>
 <a href="#3">to_3</a>
 <a href="#4">to_4</a>
 <a href="#5">to_5</a>

我们创建几个a标签,使它们跳到不同的hash,但是此时不能达到我们的预期,需要监听一个hashchange的事件。

window.addEventListener("hashchange", () => {
  console.log("hash changed");
  number = window.location.hash.substr(1);
  console.log(number);
  div = document.querySelector(`#div${number}`);
  console.log(div);
  app = document.querySelector("#app");
  div.style.display = "block";
  app.appendChild(div);
});

此时即可监听路由的hash变化
封装一下上面的代码,同时处理下404

function route() {
  let number = window.location.hash.substr(1);
  number = number || 1
  let div = document.querySelector(`#div${number}`);
  let app = document.querySelector("#app");
  if(!div) {
    div = document.querySelector(`#div404`);
  }
  div.style.display = "block";
  if(app.children.length > 0) {
    app.children[0].style.display="none"
    document.body.appendChild(app.children[0])
  }
  app.appendChild(div);
}
route()
window.addEventListener("hashchange", () => {
  route()
});

2.history模式

后端将所有前端路由都渲染到同一个页面,但IE8一下不支持

修改一下之前hash路由的代码

const div1 = document.createElement("div");
div1.innerHTML = "1";
const div2 = document.createElement("div");
div2.innerHTML = "2";
const div3 = document.createElement("div");
div3.innerHTML = "3";
const routeTable = {
  "/1": div1,
  "/2": div2,
  "/3": div3
};
function route() {
  let number = window.location.pathname;
  number = number || 1;
  let div = routeTable[number.toString()];
  let app = document.querySelector("#app");
  if (!div) {
    div = document.querySelector(`#div404`);
  }
  div.style.display = "block";
  app.appendChild(div);
}

我们创建一个路由表来存放相应的元素
此时我们能够看到路由的切换,但是这样每次都会刷新页面
我们可以先阻止a的默认效果,然后使用history.pushState

const allA = document.querySelectorAll("a.link")
for(let a of allA) {
  a.addEventListener("click",e=>{
    e.preventDefault()
    const href = a.getAttribute("href")
    window.history.pushState(null,"page 2",href)
  })
}

此时就可以想修改hash一样修改路由了,不会造成刷新页面

function onStateChange(href) {
  route()
}

for(let a of allA) {
  a.addEventListener("click",e=>{
    e.preventDefault()
    const href = a.getAttribute("href")
    window.history.pushState(null,`page-${href}`,href)
    onStateChange(href)
  })
}

此时history模式就可以自由切换了

3.memory模式

路径不通过url存储,保存在localStorage,sessionStorage等地方,适合运行在非浏览器中(比如react native,weex)中。
缺点:只对单机有效,不方便分享链接。

?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容