怎么用原生js代码实现前端简易路由
发表于:2025-11-06 作者:千家信息网编辑
千家信息网最后更新 2025年11月06日,这篇文章主要讲解了"怎么用原生js代码实现前端简易路由",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"怎么用原生js代码实现前端简易路由"吧!路由到底是
千家信息网最后更新 2025年11月06日怎么用原生js代码实现前端简易路由
这篇文章主要讲解了"怎么用原生js代码实现前端简易路由",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"怎么用原生js代码实现前端简易路由"吧!
路由到底是一个什么东西?
路由(routing)就是通过互联的网络把信息从源地址传输到目的地址的活动。路由发生在OSI网络参考模型中的第三层即网络层
通俗点来讲,路由就是把一个url 发送到后端服务器上,然后获取对应的后端资源
实现一个 hashRouter
// html部分 go to 1 go to 2 go to 3 go to 4你要找的内容被狗吃了// jsconst app = document.getElementById('app')const div1 = document.createElement('div')div1[xss_clean] = '1.components'const div2 = document.createElement('div')div2[xss_clean] = '2.components'const div3 = document.createElement('div')div3[xss_clean] = '3.components'const div4 = document.createElement('div')div4[xss_clean] = '4.components'const routerMap = { "1": div1, "2": div2, "3": div3, "4": div4}function route(container) { // 获取路由hash 值 let hashName = _window.location.hash.substr(1) console.log(hashName) hashName = hashName || '1' // 获取路由对应的组件 const components = routerMap[hashName] if(!components) { // 404 components = document.querySelector("#div404"); } components.style.display = 'block' console.log(components) // 展示界面 container[xss_clean] = ""; container.appendChild(components);}route(app)window.addEventListener('hashchange', () => { route(app);})
到这里以已经完成了一个js 版的简易路由,在不考虑嵌套的情况下,路由的基本功能已经完成,主要核心的思路其实就是使用 HTML5 中的 hash 提供的一个 api hashchange, 使用这个来监听hash 的变化, 然后去渲染不同的组件
historyRouter
const app = document.getElementById('app')const div1 = document.createElement('div')div1[xss_clean] = '1.components'const div2 = document.createElement('div')div2[xss_clean] = '2.components'const div3 = document.createElement('div')div3[xss_clean] = '3.components'const div4 = document.createElement('div')div4[xss_clean] = '4.components'const routerMap = { "/1": div1, "/2": div2, "/3": div3, "/4": div4};function route(container) { // 获取路由hash 值 let hashName = _window.location.pathname; if (hashName === "/") { hashName = "/1"; } // 获取路由对应的组件 let components = routerMap[hashName] if(!components) { // 404 components = document.querySelector("#div404"); } components.style.display = 'block' // 展示界面 container[xss_clean] = ""; container.appendChild(components);}const allA = document.querySelectorAll("a.link");for(let a of allA) { a.addEventListener('click', ()=> { e.preventDefault(); const href = a.getAttribute("href"); window.history.pushState(null, `page ${href}`, href); // 路由变化更新 onStateChange(href); })}route(app)function onStateChange() { route(app);}这里其实html部分是一样的,相比于hashRouter, 变化点在于 Hsitory 模式无法去监听路由的变化需要在变化的时候手动去更新组件, 还有就是使用的api 变成了 window.history.pushState
memoryRouter
memoryRouter 其实对于前端来说接触的不多,因为这个路由模式更多的是出现在App上,他不适合出现在h6或者pc 上, 这种路由适合看不见的地方
const app = document.getElementById('app')const div1 = document.createElement('div')div1[xss_clean] = '1.components'const div2 = document.createElement('div')div2[xss_clean] = '2.components'const div3 = document.createElement('div')div3[xss_clean] = '3.components'const div4 = document.createElement('div')div4[xss_clean] = '4.components'const routerMap = { "/1": div1, "/2": div2, "/3": div3, "/4": div4};function route(container) { // 获取路由hash 值 let number = window.localStorage.getItem("pathName"); if (hashName === "/") { hashName = "/1"; } // 获取路由对应的组件 let components = routerMap[hashName] if(!components) { // 404 components = document.querySelector("#div404"); } components.style.display = 'block' // 展示界面 container[xss_clean] = ""; container.appendChild(components);}const allA = document.querySelectorAll("a.link");for(let a of allA) { a.addEventListener('click', ()=> { e.preventDefault(); const href = a.getAttribute("href"); window.localStorage.setItem("pathName", href); // 路由变化更新 onStateChange(href); })}route(app)function onStateChange() { route(app);}上面已经实现了 memoryRouter, 其实就把路由藏起来了,在某个地方去获取
感谢各位的阅读,以上就是"怎么用原生js代码实现前端简易路由"的内容了,经过本文的学习后,相信大家对怎么用原生js代码实现前端简易路由这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
路由
变化
前端
简易
就是
组件
代码
内容
界面
网络
学习
更新
地址
地方
思路
情况
更多
模式
部分
监听
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
梦幻西游可购买的服务器
软件开发实训生有哪些工作
梦幻西游手游志存高远服务器
酷峰软件开发有限公司
将数据库设置成单用户模式
正数网络技术公司怎么样
企业服务器虚拟化用什么软件
沧州金诺网络技术公司
陕西超频服务器欢迎选购
常见网络服务器对应端口
百度法律数据库
容成网络技术有限公司怎么样
南通网络安全
tbc怀旧服有多少服务器
资阳软件开发专业定制
安全测评服务器
皇室战争服务器卡牌
实时买家数据库
杭州凤游网络技术有限公司
松江区信息化软件开发代理品牌
无锡手机软件开发创新服务
宏图三胞软件开发怎么样
远光软件开发部总经理
网络安全状况分析报告
数据库应用技术吕海洋
注册系统软件开发背景
虚拟服务器ip地址是设置多少
优融互联网科技
ntu网络安全专业
如何打开组态王的数据库