JavaScript的History API使搜索引擎抓取AJAX内容


Posted in Javascript onDecember 07, 2015

大家在浏览Facebook的相册时有没有发现,页面局部刷新的同时地址栏的地址也改变了,而且不是hash的方式。它使用的就是HTML5 history新增的几个API,作为window的一个全局变量,在HTML4的时代history已不是什么新鲜的事物了。我们经常使用的就有 history.back()以及history.go() 。

我一直以为没有办法做到,直到前两天看到了Discourse创始人之一的Robin Ward的解决方法,不禁拍案叫绝。

JavaScript的History API使搜索引擎抓取AJAX内容

Discourse是一个论坛程序,严重依赖Ajax,但是又必须让Google收录内容。它的解决方法就是放弃井号结构,采用 History API。

所谓 History API,指的是不刷新页面的情况下,改变浏览器地址栏显示的URL(准确说,是改变网页的当前状态)。这里有一个例子,你点击上方的按钮,开始播放音乐。然后,再点击下面的链接,看看发生了什么事?

JavaScript的History API使搜索引擎抓取AJAX内容

地址栏的URL变了,但是音乐播放没有中断!

History API 的详细介绍,超出这篇文章的范围。这里只简单说,它的作用就是在浏览器的History对象中,添加一条记录。

window.history.pushState(state object, title, url);

上面这行命令,可以让地址栏出现新的URL。History对象的pushState方法接受三个参数,新的URL就是第三个参数,前两个参数都可以是null。

window.history.pushState(null, null, newURL);

目前,各大浏览器都支持这个方法:Chrome(26.0+),Firefox(20.0+),IE(10.0+),Safari(5.1+),Opera(12.1+)。

下面就是Robin Ward的方法。

首先,用History API替代井号结构,让每个井号都变成正常路径的URL,这样搜索引擎就会抓取每一个网页。

example.com/1
 

example.com/2
 

example.com/3

然后,定义一个JavaScript函数,处理Ajax部分,根据网址抓取内容(假定使用jQuery)。

 function anchorClick(link) {
 
var linkSplit = link.split('/').pop();
 

$.get('api/' + linkSplit, function(data) {
 


$('#content').html(data);
 

});
 
} 

再定义鼠标的click事件。

$('#container').on('click', 'a', function(e) {
 

window.history.pushState(null, null, $(this).attr('href'));
 

anchorClick($(this).attr('href'));
 

e.preventDefault();
 
});

还要考虑到用户点击浏览器的"前进 / 后退"按钮。这时会触发History对象的popstate事件。

 window.addEventListener('popstate', function(e) {  
 
anchorClick(location.pathname); 
 
}); 

定义完上面三段代码,就能在不刷新页面的情况下,显示正常路径URL和AJAX内容。

最后,设置服务器端。

因为不使用井号结构,每个URL都是一个不同的请求。所以,要求服务器端对所有这些请求,都返回如下结构的网页,防止出现404错误。

  <html>
 
<body>
 


<section id='container'></section>
 


<noscript>
 



... ...
 


</noscript>
 

</body>
 
</html>

仔细看上面这段代码,你会发现有一个noscript标签,这就是奥妙所在。

我们把所有要让搜索引擎收录的内容,都放在noscript标签之中。这样的话,用户依然可以执行AJAX操作,不用刷新页面,但是搜索引擎会收录每个网页的主要内容!                  

Javascript 相关文章推荐
jQuery EasyUI API 中文文档 - Parser 解析器
Sep 29 Javascript
个人总结的一些JavaScript技巧、实用函数、简洁方法、编程细节
Jun 10 Javascript
微信小程序使用第三方库Underscore.js步骤详解
Sep 27 Javascript
浅谈jquery高级方法描述与应用
Oct 04 Javascript
js实现控制textarea输入字符串的个数,鼠标按下抬起判断输入字符数
Oct 25 Javascript
js Canvas绘制圆形时钟教程
Feb 06 Javascript
使用jquery+iframe做一个ajax上传效果(实例)
Aug 24 jQuery
vue+webpack 打包文件 404 页面空白的解决方法
Feb 28 Javascript
JavaScript ES6中的简写语法总结与使用技巧
Dec 30 Javascript
Vue中JS动画与Velocity.js的结合使用
Feb 13 Javascript
详解用js代码触发dom事件的实现方案
Jun 10 Javascript
vue监听dom大小改变案例
Jul 29 Javascript
JavaScript给input的value赋值引发的关于基本类型值和引用类型值问题
Dec 07 #Javascript
小巧强大的jquery layer弹窗弹层插件
Dec 06 #Javascript
使用jQuery+EasyUI实现CheckBoxTree的级联选中特效
Dec 06 #Javascript
javascript字符串函数汇总
Dec 06 #Javascript
win7下安装配置node.js+express开发环境
Dec 06 #Javascript
分享使用AngularJS创建应用的5个框架
Dec 05 #Javascript
如何利用AngularJS打造一款简单Web应用
Dec 05 #Javascript
You might like
php解析xml 的四种简单方法(附实例)
2016/07/11 PHP
php+ajax实现文件切割上传功能示例
2020/03/03 PHP
JS自调用匿名函数具体实现
2014/02/11 Javascript
TypeScript具有的几个不同特质
2015/04/07 Javascript
Javascript验证方法大全
2015/09/21 Javascript
详解JavaScript的变量和数据类型
2015/11/27 Javascript
AngularJS中的Directive实现延迟加载
2016/01/25 Javascript
JavaScript易错知识点整理
2016/12/05 Javascript
zTree树形插件异步加载方法详解
2017/06/14 Javascript
ES6 javascript的异步操作实例详解
2017/10/30 Javascript
vue生成文件本地打开查看效果的实例
2018/09/06 Javascript
js form表单input框限制20个字符,10个汉字代码实例
2019/04/12 Javascript
自定义Vue中的v-module双向绑定的实现
2019/04/17 Javascript
JS实现简易计算器
2020/02/14 Javascript
Electron实现应用打包、自动升级过程解析
2020/07/07 Javascript
Python实现检测服务器是否可以ping通的2种方法
2015/01/01 Python
使用Python对Excel进行读写操作
2017/03/30 Python
python输出数组中指定元素的所有索引示例
2019/12/06 Python
基于Python计算圆周率pi代码实例
2020/03/25 Python
python 安装impala包步骤
2020/03/28 Python
Python3获取cookie常用三种方案
2020/10/05 Python
web字体加载方案优化小结
2019/11/29 HTML / CSS
英国领先的鞋类零售商:Shoe Zone
2018/12/13 全球购物
澳大利亚音乐商店:Bava’s Music City
2019/05/05 全球购物
师范生实习自我鉴定
2013/11/01 职场文书
养殖项目策划书范文
2014/01/13 职场文书
经典导游欢迎词大全
2014/01/16 职场文书
幼儿园消防安全制度
2014/01/26 职场文书
知识竞赛活动方案
2014/02/18 职场文书
办公室打字员岗位职责
2014/04/16 职场文书
关于九一八事变的演讲稿2014
2014/09/17 职场文书
放弃遗产继承公证书
2015/01/26 职场文书
八年级历史教学反思
2016/02/19 职场文书
市语委办2016年第十九届“推普周”活动总结
2016/04/05 职场文书
浅谈:电影《孔子》观后感(范文)
2019/10/14 职场文书
Nginx配置https原理及实现过程详解
2021/03/31 Servers