美文网首页
前端路由

前端路由

作者: 西域战神 | 来源:发表于2021-01-10 11:17 被阅读0次

路由是什么

路由是用来分发请求

路由模式

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.pngimage.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)中。
缺点:只对单机有效,不方便分享链接。

相关文章

  • 第三十一节:Vue路由:前端路由vs后端路由的了解

    1. 认识前端路由和后端路由 前端路由相对于后端路由而言的, 在理解前端路由之前先对于路由有一个基本的了解 路由:...

  • 前端微服务化解决方案5 - 路由分发

    路由分发式微前端 从应用分发路由到路由分发应用 用这句话来解释,微前端的路由,再合适不过来. 路由分发式微前端,即...

  • vue - 路由模式

    1 路由的基本概念与原理 路由的本质就是对应关系; 在开发中, 路由分为前端路由和后端路由. 1.1 前端路由 概...

  • react-router-dom

    一、什么是前端路由 在我看来,前端路由和网络上的路由器功能很像。前端路由也是进行分发操作,只不过其分发的是页面跳转...

  • vue基础-路由(重要)

    前端路由的概念与原理 什么是前端路由 Hash 地址与组件之间的映射关系,前端路由可以将hash地址和组件关联起来...

  • CreateReactApp+ReactRouter4的使用

    路由基础介绍1,什么是前端路由? 路由是根据不同的 url 地址展示不同的内容或页面 前端路由就是把不同路由对应不...

  • 面试:谈谈对前端路由的理解?

    面试官想听到什么答案呢? 1、为什么会出现前端路由。 2、前端路由解决了什么问题。 3、前端路由实现的原理是什么。...

  • 前端路由(一)

    前端路由之变化url不发送请求 什么是路由?为什么要有前端路由? 首先,域名的组成:http://(协议)www....

  • vue学习笔记——vue-router

    1.什么是前端路由? 前端路由是根据不同的URL地址显示不同的内容或页面。 2.什么时候使用前端路由? 在单页面应...

  • vue-router 原理

    1、前端路由 在 Web 前端单页应用 SPA(Single Page Application)中,路由描述的是 ...

网友评论

      本文标题:前端路由

      本文链接:https://www.haomeiwen.com/subject/tmekaktx.html