在 js 中,有一种方法,可以在不刷新页面的情况下,页面的内容进行变更,ajax 是一种,这里介绍另一种,就是 哈希路由原理

先看一个简单的路由和页面内容关联的例子,要实现两个功能:

1.1. 浏览器的路由变化,页面内容跟着变化

1.2.页面内容变换,浏览器的内容跟着变化

实现过程:

1.3.设定一个页面按钮,点击按钮时,改变页面的内容

1.4.设定浏览器的内容,跟随页面内容的变化而变化,即:直接赋值给浏览器的hash属性就可以了

1.5.监听浏览器的hash值,如果hsah改变了,则页面内容跟随变化

代码:

 <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<script>
window.onload = function(){
var getoneNum = function(start,end){
var rand_num = Math.random();
var range = end - start ;
return start + Math.round( (Math.random() * range) );
};
var getnums = function(start,end,n){
var arr = [];
for(var i=0;i<n;i++){
arr.push( getoneNum(start,end) );
};
return arr ;
};
function Ohash(){
this.ospan = document.querySelector('.ospan');
this.obtn = document.querySelector('input');
};
Ohash.prototype.bind = function(){
var that = this;
this.obtn.onclick = function(){
location.hash = getnums(3,108,6);
that.ospan.innerHTML = location.hash.substring(1) ;
};
window.onhashchange = function(){
that.ospan.innerHTML = location.hash.substring(1)||'' ;
};
};
var Oha = new Ohash();
Oha.bind();
}
</script>
</head>
<body>
<div class='box'>
<input type="submit" value="触发按钮">
<span class="ospan"></span>
</div>
</body>
</html>

运行结果:实现了hash 值与页面内容的关联变化

2.类似的,通过页面的无刷新,仅改变页面的 hash 值,而达到页面内容的变更

2.1 构造一个路由函数

2.2 对路由的hash值进行监听,如果hash 发生改变,则执行加载函数

2.3 定义路由配置规则

2.4 对路由进行初始化即调用

html 代码:

 <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<link rel="stylesheet" href="./css/router.css">
<script src="./js/router.js"></script>
<style> </style> </head>
<body>
<header>这里是头部</header>
<nav>
<li><a href="#/">aluoa</a> </li>
<li><a href="#/01">huanying2015</a> </li>
<li> <a href="#/02">一代天骄</a> </li>
<li> <a href="#/03">霸王</a> </li>
<li><a href="#/04">秦始皇</a> </li>
<li><a href="#/05">释迦摩尼</a> </li>
</nav>
<section>
如果想看路由改变效果,请点击左边的链接
</section>
<div class="clear"></div>
<footer>这里是尾部</footer>
</body>
</html>

css 代码:

  header,footer{
height:5em;
background: #cba;
text-align: center;
line-height: 5em;
}
nav{
width:20%;
height:30em;
background: #391;
float:left;
}
li{
height:2em;
} section{
width:80%;
background: #9a1;
height:30em;
float:right;
line-height: 2em;
text-align: center;
}
.clear{
clear:both;
}

js代码:

 window.onload = function(){
(function(){
var Router=function(){
this.routes={};
this.curUrl='/';
};
// 对路由的hash值进行监听,如果发生改变,则调用reloadPage()函数
Router.prototype.init= function(){
// 这里的两个this 是不一样的,需要注意
window.addEventListener('hashchange',this.reloadPage.bind(this) );
};
// 调用reloadPage函数,实际上时执行routes[]()函数
Router.prototype.reloadPage = function(){
this.curUrl = location.hash.substring(1)||'/';
this.routes[this.curUrl]();
};
// 路由配置的规则
Router.prototype.map = function(key,callback){
this.routes[key] = callback;
}
window.Router = Router;
})(); var ORouter = new Router();
ORouter.init(); // 以下为路由配置的设置,形象的当做一个路由与调用函数的映射表也可以
ORouter.map('/',function(){
var Osect = document.querySelector('section');
Osect.innerHTML = "欢迎来到火星,这是一次非常的旅行,祝您路途愉快!";
});
ORouter.map('/01',function(){
var Osect = document.querySelector('section');
Osect.innerHTML = "huanying2015 huanying2015 huanying2015 huanying2015 huanying2015 huanying2015 huanying2015 huanying2015 huanying2015 huanying2015 huanying2015 huanying2015 huanying2015 ";
});
ORouter.map('/02',function(){
var Osect = document.querySelector('section');
Osect.innerHTML = "hehehehehheeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeheheehehehhehehehhehehehehheeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeheheehehehhehehehhehehehehheeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeheheehehehheheheh";
});
ORouter.map('/03',function(){
var Osect = document.querySelector('section');
Osect.innerHTML = "nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao nihao ";
});
ORouter.map('/04',function(){
var Osect = document.querySelector('section');
Osect.innerHTML = "i am fine i am fine i am fine i am fine i am fine i am fine i am fine i am fine i am fine i am fine i am fine i am fine i am fine i am fine i am fine i am fine i am fine ";
});
ORouter.map('/05',function(){
var Osect = document.querySelector('section');
Osect.innerHTML = "good night ood night ood night ood night ood night ood night ood night ood night ood night ood night ood night ood night ood night ood night ood night ood night ood night ood night ";
});
}

运行结果:

js 哈希路由原理实现的更多相关文章

  1. hash路由(哈希路由)

    1.https://www.cnblogs.com/huanying2015/p/8047376.html (js 哈希路由原理实现) 2.https://www.cnblogs.com/yeer/a ...

  2. 前端路由原理及vue-router介绍

    前端路由原理本质就是监听 URL 的变化,然后匹配路由规则,显示相应的页面,并且无须刷新.目前单页面使用的路由就只有两种实现方式 hash history www.test.com/##/ 就是 Ha ...

  3. vue路由原理剖析

    单页面应用(SPA)的核心之一是: 更新视图而不重新请求页面, 实现这一点主要是两种方式: 1.Hash: 通过改变hash值 2.History: 利用history对象新特性(详情可出门左拐见:  ...

  4. Mysql系列六:(Mycat分片路由原理、Mycat常用分片规则及对应源码介绍)

    一.Mycat分片路由原理 我们先来看下面的一个SQL在Mycat里面是如何执行的: , ); 有3个分片dn1,dn2,dn3, id=5000001这条数据在dn2上,id=10000001这条数 ...

  5. vue-router路由原理

    Vue-router路由原理 目前实现路由的方式有两中,vue通过参数mode来设置,默认是hash模式. 利用URL中的hash(‘#’)来实现 利用History interface在HTML5中 ...

  6. director.js实现前端路由

    注:director.js的官网 https://github.com/flatiron/director director.js是什么? 理解:前端的route框架,director.js客户端的路 ...

  7. js 实现前端路由的方法

    js 实现前端路由的方法 前端路由原理 History API https://developer.mozilla.org/en-US/docs/Web/API/History_API https:/ ...

  8. 从路由原理出发,深入阅读理解react-router 4.0的源码

      react-router等前端路由的原理大致相同,可以实现无刷新的条件下切换显示不同的页面.路由的本质就是页面的URL发生改变时,页面的显示结果可以根据URL的变化而变化,但是页面不会刷新.通过前 ...

  9. SQL Server2014 哈希索引原理

    SQL Server2014 哈希索引原理 翻译自:http://www.sqlservercentral.com/blogs/sql-and-sql-only/2015/09/08/hekaton- ...

随机推荐

  1. javascript中数组与字符串之间的转换以及字符串的替换

    数组转化为字符串: var a=['aa','bb','cc']; var b=a.join('-'); console.log(b)----->'aa-bb-cc' 字符串中的替换: 1.re ...

  2. ionic3.0--angular4.0 引入第三方插件库的方法

    ionic3.0 引入第三方插件 (swiper),方法很多,现详细说明下官方推荐(typings)做法. 1.全局安装Typings 1. npm install -g typings  2.搜索你 ...

  3. HTML 3秒一换轮播(鼠标选中旋转停止定时) 动画案例

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. 到底vuex是什么?

    Vuex 什么是Vuex? 官方说法:Vuex 是一个专为 Vue.js应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化. 个人理 ...

  5. Windows系统安装MySQL

    在Windows中安装mysql不够幸运的话,会遇到相当多的坑,当然这也算是一种财富吧,让自己碰到问题去查找解决方案.有时候不是一时半会就可以解决的.有同学说过安装mysql安装两天还没有装上.不用担 ...

  6. Docker简介和安装

    1.Docker 和传统虚拟化方式的不同之处 传统虚拟机技术是虚拟出一套硬件后,在其上运行一个完整操作系统,在该系统上再运行所需应用进程: 而容器内的应用进程直接运行于宿主的内核,容器内没有自己的内核 ...

  7. java多线程创建-Thread,Runnable,callable和threadpool

    java创建多线程的方式有许多种,这里简要做个梳理 1. 继承Thread类 继承java.lang.Thread类,创建本地多线程的类,重载run()方法,调用Thread的方法启动线程.示例代码如 ...

  8. python 有关datetime时间日期 以及时间戳转换

    直接上代码 其中有注释 #coding=utf-8 import time import datetime def yes_time(): #获取当前时间 now_time = datetime.da ...

  9. 设计模式的征途—10.装饰(Decorator)模式

    虽然目前房价依旧很高,就连我所在的成都郊区(非中心城区)的房价均价都早已破万,但却还是阻挡不了大家对新房的渴望和买房的热情.如果大家买的是清水房,那么无疑还有一项艰巨的任务在等着大家,那就是装修.对新 ...

  10. matlab R2016a 中添加新的工具箱的方法

    matlab添加新的工具箱分三步: 1. 下载新的工具箱,并解压. 2. 将解压后的工具箱文件夹移到安装的matlab中的toolbox文件夹中 3. 添加新文件夹及其子文件夹到路径中. 接下来以添加 ...